由于公司上网实行代理机制,
而最近一段时间又在研究Web上的OpenApi。
没办法一定要使用代理,我之前有文章介绍了httpclient的代理使用方式,
这里介绍基本java的代理使用方式。
最常使用的全局配置代理。
Properties prop = System.getProperties();
// HTTP代理的IP设置
prop.setProperty("http.proxyHost", "10.28.0.254");
// HTTP代理的端口设置
prop.setProperty("http.proxyPort", "80");
//这里也可以设置不需要使用代理的地址
prop.setProperty("http.nonProxyHosts", "localhost|10.28.0.*");
//设置HTTPS安全访问的代理服务器地址与端口
prop.setProperty("https.proxyHost", "10.28.0.254");
prop.setProperty("https.proxyPort", "443");
//对于安全访问的过滤地址属性同样是http.nonProxyHosts并没有https.nonProxyHosts
//FTP的代理设置入下
prop.setProperty("ftp.proxyHost", "192.168.0.254");
prop.setProperty("ftp.proxyPort", "2121");
prop.setProperty("ftp.nonProxyHosts", "localhost|192.168.0.*");
//SOCKS的代理设置
prop.setProperty("socksProxyHost", "192.168.0.254");
prop.setProperty("socksProxyPort", "8000");
有时代理需要进行身份验证 此时我们需要自己定义一个继承类Authenticator的类
public class MyAuthenticator extends Authenticator {
private String username = "";
private String password = "";
public MyAuthenticator(String username, String password) {
this.username = username;
this.password = password;
}
protected PasswordAuthentication getPasswordAuthentication() {
returnnew PasswordAuthentication(username, password.toCharArray());
}
}
//设置登陆到代理服务器的用户名和密码
Authenticator.setDefault(new MyAuthenticator("userName", "Password"));
当然此种方法可以满足大部分的需求 但是有一定的局限行,
就是所有的连接通过统一属性进行代理配置的,不能对特定连接进行代理配置。
JDK5及其之后版本引入新的代理配置,可以满足对特定连接进行配置
URL url = new URL("http://www.shanhe114.com");
//创建代理服务器
InetSocketAddress addr = new InetSocketAddress("10.28.0.4",
8080);
//Proxy proxy = new Proxy(Proxy.Type.SOCKS, addr); //SOCKS代理
Proxy proxy = new Proxy(Proxy.Type.HTTP, addr); //HTTP代理
//其他方式可以见Proxy.Type属性
URLConnection conn = url.openConnection(proxy);
InputStream in = conn.getInputStream();
//InputStream in = url.openStream();
String content = IOUtils.toString(in);
System.out.println(content);
长春都市网
如果大家对JEE的深入研究有兴趣
可以加入Q群:46176507 共同进步学习