J2SE5.0新特性之利用署理处事器
J2SE1.5也被称为J2SE5.0,在5.0以前的署理处事器配置挺不友好,此刻,5.0提供了对通过署理处事器的越发机动的节制,它可以对http,https,ftp,socks等别离配置,并且还可以配置不需要通过署理处事器的主机和地点。这和我们在IE、firefox中配置署理处事器雷同。
1.你可以在通过java -DXXXX=YYYY方法在措施启动时配置,你也可以在措施中将配置放入系统属性中,你也可以配置Proxy类,通过它来节制。
2.可以通过ProxySelector来做本身的署理处事器的负载均衡等。
package com.kuaff.jdk5package;
import java.io.IOException;
import java.io.InputStream;
import java.net.InetSocketAddress;
import java.net.MalformedURLException;
import java.net.Proxy;
import java.net.ProxySelector;
import java.net.SocketAddress;
import java.net.URI;
import java.net.URISyntaxException;
import java.net.URL;
import java.net.URLConnection;
import java.util.List;
import java.util.Properties;
public class NetProxy
{
// 测试当地JVM的网络缺省设置
public void setLocalProxy()
{
Properties prop = System.getProperties();
//配置http会见要利用的署理处事器的地点
prop.setProperty("http.proxyHost", "10.10.0.96");
//配置http会见要利用的署理处事器的端口
prop.setProperty("http.proxyPort", "8080");
//配置不需要通过署理处事器会见的主机,可以利用*通配符,多个地点用|脱离
prop.setProperty("http.nonProxyHosts", "localhost|10.10.*");
//配置安详会见利用的署理处事器地点与端口
//它没有https.nonProxyHosts属性,它凭据http.nonProxyHosts 中配置的法则会见
prop.setProperty("https.proxyHost", "10.10.0.96");
prop.setProperty("https.proxyPort", "443");
//利用ftp署理处事器的主机、端口以及不需要利用ftp署理处事器的主机
prop.setProperty("ftp.proxyHost", "10.10.0.96");
prop.setProperty("ftp.proxyPort", "2121");
prop.setProperty("ftp.nonProxyHosts", "localhost|10.10.*");
//socks署理处事器的地点与端口
prop.setProperty("socksProxyHost", "10.10.0.96");
prop.setProperty("socksProxyPort", "1080");
}
// 排除proxy配置
public void removeLocalProxy()
{
Properties prop = System.getProperties();
prop.remove("http.proxyHost");
prop.remove("http.proxyPort");
prop.remove("http.nonProxyHosts");
prop.remove("https.proxyHost");
prop.remove("https.proxyPort");
prop.remove("ftp.proxyHost");
prop.remove("ftp.proxyPort");
prop.remove("ftp.nonProxyHosts");
prop.remove("socksProxyHost");
prop.remove("socksProxyPort");
}
//
// 测试http
public void showHttpProxy(Object... proxy)
{
URL url = null;
try
{
url = new URL("http://blog.csdn.com/smallnest");
}
catch (MalformedURLException e)
{
return;
}
try
{
URLConnection conn = null;
switch (proxy.length)
{
case 0:
conn = url.openConnection();
break;
case 1:
conn = url.openConnection((Proxy) proxy[0]);
break;
default:
break;
}
if (conn == null)
return;
conn.setConnectTimeout(3000); // 配置毗连超时时间
InputStream in = conn.getInputStream();
byte[] b = new byte[1024];
try
{
while (in.read(b) > 0)
{
System.out.println(new String(b));
}
}
catch (IOException e1)
{
}
}
catch (IOException e1)
{
e1.printStackTrace();
}
}
// 测试ftp
public void showFtpProxy(Object... proxy)
{
URL url = null;
try
{
url = new URL("ftp://ftp.tsinghua.edu.cn");
}
catch (MalformedURLException e)
{
return;
}
try
{
URLConnection conn = null;
switch (proxy.length)
{
case 0:
conn = url.openConnection();
break;
case 1:
conn = url.openConnection((Proxy) proxy[0]);
break;
default:
break;
}
if (conn == null)
return;
conn.setConnectTimeout(3000); // 配置毗连超时时间
InputStream in = conn.getInputStream();
byte[] b = new byte[1024];
try
{
while (in.read(b) > 0)
{
System.out.println(new String(b));
}
}
catch (IOException e1)
{
}
}
catch (IOException e1)
{
e1.printStackTrace();
}
}
// 获得一个proxy
public Proxy getProxy(Proxy.Type type, String host, int port)
{
SocketAddress addr = new InetSocketAddress(host,port);
Proxy typeProxy = new Proxy(type, addr);
return typeProxy;
}
public static void main(String[] args)
{
NetProxy proxy = new NetProxy();
//测试署理处事器
proxy.setLocalProxy();
proxy.showHttpProxy();
//下面两行是排除系统属性,而通过Proxy类指定署理处事器
// proxy.removeLocalProxy
//proxy.showHttpProxy(proxy.getProxy(Proxy.Type.SOCKS,"10.10.0.96",1080));
}
}