95992828九五至尊2

Windows客户端程序在代理环境下的相关设置,java中安装互连网代理882828九五至尊手机版

二月 22nd, 2019  |  882828九五至尊手机版

此间是少数经验的简练计算

代理服务器概述

有的是系统经过代理服务器访问Web,有时还会造访Internet的其余非HTTP部分。代理服务器接收到当地客户端到长途服务器的乞请。代理服务器向远程服务器发出请求,再将结果转载回当地客户端。

事先在用SmartClient+Remoting的方法开发业务管理系统的时候,就碰着过一遍HTTP代理配置的题材。当时,由于Remoting不大概自动配置代理,所以使用的点子就是在登录界面上提供代理网络布局的选项,让用户手动录入代理服务器的地址,端口,用户名和密码。

代理服务器成效:

1.防备攻击
隐身自个儿的真实性地址新闻,还可隐藏本人的IP,幸免被黑客攻击。
2.缓存
把平日访问的局地文档、页面缓存到代理服务器上,这样,可以缩短访问从远程服务器上下载文档、页面。
3.限制出站连接
譬如:集团会利用代理服务器配置部分网址,阻止访问外网(购物网站等)。

在.NET 4.0中对于Web
Service和WCF,就足以经过设置WebRequest.DefaultWebProxy.Credentials =
CredentialCache.DefaultNetworkCredentials;来机关配置领先52%代理服务器。那种格局实际上就是拔取IE中对代理服务器的安插。

java中安排代理

java中支持 HTTP代理、HTTPS代理、Socket代理、FTP代理 等。

  1. HTTP
    http.proxyHost
    http.proxyPort [默认值:80]
    http.nonProxyHosts

  2. HTTPS
    https.proxyHost
    https.proxyPort [默认值:443]
    https.nonProxyHosts

  3. FTP
    ftp.proxyHost
    ftp.proxyPort [默认值:80]
    ftp.nonProxyHosts

  4. SOCKS
    socksProxyHost
    socksProxyPort [默认值:1080]

上边大家以HTTP代理来表达java中扶助代理完毕的两种方法

对于DefaultNetworkCredentials的行使可以参考小编其它一篇博客:DefaultNetworkCredentials
vs
DefaultCredentials

搭建代理服务器

那里运用的是CCProxy搭建的代理服务器。

  1. 陈设代理协议和端口
![](https://upload-images.jianshu.io/upload_images/2843224-b55bf2972054c863.png)

Paste\_Image.png
  1. 布署认证用户、密码音讯
![](https://upload-images.jianshu.io/upload_images/2843224-21db64d01ceecf80.png)

Paste\_Image.png

通过上述代码配置后,并不大概担保一定能科学访问,所以还要求举办如下处理:

JVM参数设置代理

在系统运营时,使用-D项来安装代理。
例如:
java -Dhttp.ProxyHost=192.168.10.130 -Dhttp.ProxyPort=808
cn.com.infcn.ProxyDemo

代办的功效域:整个系统

只要代理要求用户名和密码,则必要通过Authenticator.setDefault(自定义的Authenticator)
来设置用户名密码,上边会介绍。

  1. 通过代码配置为私行认同代理后
  2. 做客一下互联网是还是不是衔接
  3. 如果没有连接,尤其访问407以此评释错误的代码,
  4. 那么就须要指示用户输入代理服务器用户名和密码

系统参数设置代理

在代码中通过System.setProperty设置代理:

System.setProperty("http.proxyHost", "192.168.10.130");
System.setProperty("http.proxyPort", "808");
System.setProperty("http.nonProxyHosts", "192.168.3.249 | 192.168.3.100");

代办的效能域:整个连串

自作者的兑现代码如下:

动用Proxy 设置代理

代码中得以应用Proxy类给单个U途锐L连接钦赐代理,使程序尤其灵活的采用代理:

SocketAddress sa = new InetSocketAddress("192.168.10.130", 808);
Proxy proxy = new Proxy(Proxy.Type.HTTP, sa);

URL url = new URL("http://192.168.3.249:8090/webDemo/index.jsp");
url.openConnection(proxy );

代理的成效域:指定的ULX570L

custom code for set proxy//参考:http://www.codeguru.com/csharp/csharp/cs_network/http/article.php/c16479
_CanConnectedIKE = false;
HttpWebRequest httpReq = (HttpWebRequest)WebRequest.Create("http://www.itke.com.cn/ping.txt");
httpReq.AllowAutoRedirect = false;
HttpWebResponse httpRes;
WebRequest.DefaultWebProxy.Credentials = CredentialCache.DefaultNetworkCredentials;
try
{
    httpRes = (HttpWebResponse)httpReq.GetResponse();
    if (httpRes.StatusCode == HttpStatusCode.OK)
    {
        httpRes.Close();
        _CanConnectedIKE = true;
    }
    httpRes.Close();
}
catch (WebException ex)
{
    if (ex.Message.Contains("407"))
    {                            
        ProxyAuthDialog dialog = new ProxyAuthDialog();
        dialog.ShowDialog();
        WebRequest.DefaultWebProxy.Credentials = new NetworkCredential(
            dialog.Username, dialog.Password);
        try
        {
            httpReq = (HttpWebRequest)WebRequest.Create("http://www.itke.com.cn/ping.txt");
            httpRes = (HttpWebResponse)httpReq.GetResponse();
            if (httpRes.StatusCode == HttpStatusCode.OK)
            {
                httpRes.Close();
                _CanConnectedIKE = true;
            }
        }
        catch (Exception ex1)
        {
            ProgramBase.Logger.WriteException(ex1);
        }
    }
}

亟待表明的代办

java.net包中提供了Authenticator类,可以采纳他为HTTP认证提供用户名和口令。

public abstract class Authenticator

她是个抽象类,用户需求为此类落成二个子类,来贯彻认证作用。

子类必要贯彻Authenticator类中的requestPasswordAuthentication方法

public static PasswordAuthentication requestPasswordAuthentication

当U宝马7系L要求用户名和口令的时候,系统会活动调用requestPasswordAuthentication方法。

采用静态方法Authenticator.setDefault(Authenticator
a)来注册自身已毕的子类。

上边通过代码来演示Authenticator的应用。

public class MyAuthenticator extends Authenticator {
    private String user = "";
    private String password = "";
    public MyAuthenticator(String user, String password) {
        this.user = user;
        this.password = password;
    }
    protected PasswordAuthentication getPasswordAuthentication() {
        return new PasswordAuthentication(user, password.toCharArray());
    }
}

public class ProxyAuthDemo{
    public static void main(String[] args) throws Exception {
        Authenticator.setDefault(new MyAuthenticator("infcn", "123456"));

        SocketAddress sa = new InetSocketAddress("192.168.10.130", 808);
        Proxy proxy = new Proxy(Proxy.Type.HTTP, sa);

        URL url = new URL("http://192.168.3.249:8090/webDemo/index.jsp");
        HttpURLConnection conn = (HttpURLConnection)url.openConnection(proxy );
        BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
        String line = null;
        while((line=br.readLine())!=null){
            System.out.println(line);
        }
        br.close();
}

运转结果:

882828九五至尊手机版 1

Paste_Image.png

从呼吁结果中可发现,服务器获取的ip是代理服务器的ip(192.168.10.130),那样就隐藏了确实访问者ip(192.168.3.249)。
本机ip :192.168.3.249
代理服务器ip : 192.168.10.130

除去通过代码来配置默许代理外,也得以在布局文件中对WCF等展开计划,如下:

HTTP 请求头 认证

使用注册Authenticator格局证北宋理访问,然后经过抓包工具发现,请求头中多了Proxy-authorization项。

882828九五至尊手机版 2

Paste_Image.png

从图中得以观看代理认证情势是应用basic认证的。
basic认证是使用 “用户名:密码”
然后经过base64转码的法子。也等于众人传输的。

下边大家透过请求头中安排Proxy-authorization来说南陈理。

代码如下:

public class ProxyAuthDemo{
    public static void main(String[] args) throws Exception {
        SocketAddress sa = new InetSocketAddress("192.168.10.130", 808);
        Proxy proxy = new Proxy(Proxy.Type.HTTP, sa);

        URL url = new URL("http://192.168.3.249:8090/webDemo/index.jsp");
        HttpURLConnection conn = (HttpURLConnection)url.openConnection(proxy );

        //用户名:密码  格式然后base64转码成ascii格式的(请求头不能使用非ascii的编码)
        String basic = Base64.getEncoder().encodeToString("infcn:123456".getBytes());
        conn.setRequestProperty("Proxy-authorization", "Basic " + basic);

        BufferedReader br = new BufferedReader(new InputStreamReader(conn.getInputStream()));
        String line = null;
        while((line=br.readLine())!=null){
            System.out.println(line);
        }
        br.close();
}

运营输出的结果如下:

882828九五至尊手机版 3

Paste_Image.png

参照官方文档

<basicHttpBinding>

  <binding name="MyClientBinding" proxyAddress="http://gateway:8080" useDefaultWebProxy="false">

  </binding>

</basicHttpBinding>

or

<customBinding>

  <binding name="MyCustomClientBinding">

    <binaryMessageEncoding />

    <httpTransport proxyAddress="http://gateway:8080" useDefaultWebProxy="false" />

  </binding>

</customBinding>

or

<system.net>

  <defaultProxy useDefaultCredentials="true">

    <proxy bypassonlocal="False" proxyaddress="http://gateway:8080" />

  </defaultProxy>

</system.net>

相关文章

Your Comments

近期评论

    功能


    网站地图xml地图