http 代理 测试

Technorati 标记: http 代理验证及测试

Technorati 标记: C#

using System;
using System.Collections;
using System.Collections.Generic;
using System.Configuration;
using System.Diagnostics.Contracts;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.NetworkInformation;
using System.Text;
using System.Threading.Tasks;
using static System.Console;
using static System.GC;
using static System.Net.WebRequest;

namespace 代理测试
{
    class Program
    {
        int printCount;
        Uri uri;
        Encoding bin;
        string[] IpSectionSpan = { "10.197.255.", "10.197.198." };
        NetworkCredential credit;

        [STAThread]
        static void Main(string[] args)
        {
            new Program();
            ReadKey();
        }

        public Program()
        {
            var dr = new AppSettingsReader();

            credit = new NetworkCredential(
                dr.GetValue("uid", typeof(string)).ToString(),
                dr.GetValue("pwd", typeof(string)).ToString());

            //var creadentiCache = new CredentialCache();
            uri = new Uri("http://wwww.baidu.com/");

            bin = Encoding.GetEncoding("UTF-8");

            //测试 IpSectionSpan 中所有IP段中所有IP
            TestIPSetions();
        }

        private void TestIPSetions()
        {
            //for (int i = 1; i < 255; i++)
            //{
                TestInSpan(198.ToString());
            //}
        }

        private void TestInSpan(string ipSect)
        {
            for (var i = 255; i > 0; i--)
            {
                var wproxy = new WebProxy(@"10.137." + ipSect + "." + i, 3128);
                //uri = new Uri("http://10.137.255." + i+":3128/");
                //creadentiCache.Add(uri, "Basic", credit);
                //wproxy.Credentials = creadentiCache;
                wproxy.Credentials = credit;

                //Collect();
                var req = Create(uri) as HttpWebRequest;
                req.PreAuthenticate = true;
                req.Timeout = 1000; //超时
                req.Proxy = wproxy;
                req.KeepAlive = false;

                try
                {
                    WebResponse resp;

                    req.BeginGetResponse(ra =>
                    {
                        try
                        {
                            using (resp = req.EndGetResponse(ra))
                            {
                                if (resp != null)
                                {
                                    var sr = new StreamReader(resp.GetResponseStream(), bin);
                                    var str = sr.ReadToEnd();
                                    if (!str.Contains("百度")) return;
                                    WriteLine("{0}\t:{1} \t 验证成功!", printCount++, wproxy.Address);
                                    sr.Close();
                                    sr.Dispose();
                                }
                            }
                        }
                        catch (Exception ex)
                        {
                            WriteLine("{0}\t:{1} \t 验证失败,失败原因:\t {2}", printCount++, wproxy.Address, ex.Message);
                        }

                    }, null);
                }
                catch (Exception e)
                {
                    WriteLine(e.Message);
                }
            }
        }
    }
} 
时间: 2024-10-06 21:55:54

http 代理 测试的相关文章

QUnit利用代理测试不同PHP开发服务器的json服务

在手机应用开发过程中,有以下单元测试的需求: 服务器用PHP代码写,自身没有好的单元测试框架: 服务器有:本地服务器,测试服务器,UAT服务器,正式服务器等不同环境: 测试脚本,利用qunit,写在js代码中:login脚本会设置cookie,某些api调用的时候,需要将cookie带回: 如何搭建各种不同的测试环境: 本地服务器.测试服务器.UAT服务器.正式服务器,都配置了vhost,将域名对应到各自本地的php目录. 正式的域名www.xxxxxx.com,指向正式服务器的IP,其他的开发

Linux 基于LAMT反向代理测试

测试环境:CentOS 6.8   Tomcat 测试环境 : CentOS 7.3    Apache 软件版本:jdk-8u144-linux-x64.tar.gz apache-tomcat-8.0.45.tar.gz Apache 2.4.6 需要用到DNS服务解析,如果没有的话 修改/etc/hosts添加相对应的ip地址和相对应的域名. 1.在CentOS 6.8上安装tomcat 创建tomcat用户并指定id号为601. ]#useradd -u 601 tomcat 解压jdk

Java 通过代理测试webService接口

以下代码针是针对电脑是通过代理上网的情况时使用: System.getProperties().put("http.proxyHost", "192.168.13.19");//代理服务器IP地址 System.getProperties().put("http.proxyPort", "7777");//代理服务器端口 调用接口代码 参考文档:http://llying.iteye.com/blog/465253

nginx 安装与反向代理测试 under MAC

安装 在 Mac 下可以直接使用 homebrew 安装 nginx brew search nginx brew install nginx 启动 nginx: sudo nginx,访问 8080 应能看到欢迎界面 nginx -V 查看 nginx 的启动参数,配置文件的位置默认是 --conf-path=/usr/local/etc/nginx/nginx.conf #重新加载配置|重启|停止|退出 nginx nginx -s reload|reopen|stop|quit 反向代理

Java设计模式——代理模式

前言: 上一篇说到了策略模式.单类图上来说,它和本篇要说的代理模式还真是有些像似.都需要一个公共的接口,还有一些实现类.代理类(包装类)封装了一个接口对象,提供客户端调用.这些都很类似.不过,有一个细节需要我们注意一下,那就是这里的代理类也需要去继承这里的公共接口.而在策略模式中,包装类则不需要这么做. 概述: 代理模式就是定义一个原对象的代理对象,来帮助原对象和系统之外的业务作沟通.也就是说,如果我们不能直接或是不愿直接去使用原对象,那么我们就可以使用创建一个原对象的代理来进行操作. 本文链接

Java进阶之 JDK动态代理与Cglib动态代理

一.动态代理概述: 与静态代理对照(关于静态代理的介绍 可以阅读上一篇:JAVA设计模式之 代理模式[Proxy Pattern]), 动态代理类的字节码是在程序运行时由Java反射机制动态生成. 注意: 1.AspectJ是采用编译时生成AOP代理类,具有更好的性能,但是需要使用特定的编译器进行处理 2.Spring AOP采用运行时生成AOP代理类,无需使用特定编译器进行处理,但是性能相对于AspectJ较差 二.JDK动态代理 [对有实现接口的对象做代理] 1.JDK动态代理中 需要了解的

网站渗透测试原理及详细过程

网站渗透测试原理及详细过程 渗透测试(Penetration Testing)目录 零.前言一.简介二.制定实施方案三.具体操作过程四.生成报告五.测试过程中的风险及规避参考资料FAQ集 零.前言 渗透测试在未得到被测试方授权之前依据某些地区法律规定是违法行为. 这里我们提供的所有渗透测试方法均为(假设为)合法的评估服务,也就是通常所说的道德黑客行为(Ethical hacking),因此我们这里的所有读者应当都是Ethical Hackers,如果您还不是,那么我希望您到过这里后会成为他们中的

JDK动态代理实现原理

之前虽然会用JDK的动态代理,但是有些问题却一直没有搞明白.比如说:InvocationHandler的invoke方法是由谁来调用的,代理对象是怎么生成的.直到看了他的文章才彻底明白,附网址:http://rejoy.iteye.com/blog/1627405 Java代码   package dynamic.proxy; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import j

Linux下squid代理缓存服务环境部署

代理服务器英文全称是Proxy Server,其功能就是代理网络用户去取得网络信息. Squid是一个缓存Internet 数据的软件,其接收用户的下载申请,并自动处理所下载的数据.当一个用户想要下载一个主页时,可以向Squid 发出一个申请,要Squid 代替其进行下载,然后Squid 连接所申请网站并请求该主页,接着把该主页传给用户同时保留一个备份,当别的用户申请同样的页面时,Squid 把保存的备份立即传给用户,使用户觉得速度相当快.Squid 可以代理HTTP.FTP.GOPHER.SS