本文目錄一覽:
java通過代理ip方式訪問接口返回為null
自動報錯。null是Java中的關鍵字。null==0x0表示內存中編號為0的地址。該地址受到系統保護,任何程序讀取,寫入0x0地址,系統直接殺死程序會自動報錯。一般用於在開發中初始化引用數據類型的變量,利用null報錯。NullPointerException。null是一種特殊的值,可以把null賦予任何引用類型,也可以把null轉化成任何類型。但是僅僅限於引用類型,不包括基本數據類型。
Java 中怎樣在程序中設置代理服務器
從JDK1.5開始,Java在java.net包下提供了Proxy和ProxySelector兩個類,其中Proxy代表一個代理服務器,可以在打開URLConnection連接時指定所用的Proxy實例,也可以在創建Socket連接時指定Proxy實例。而ProxySelector代表一個代理選擇器,它提供了對代理服務器更加靈活的控制,它可以對HTTP、HTTPS、FTP、SOCKS等分別設置,而且還可以設置不需要通過代理服務器的主機和地址。通過使用ProxySelector可以達到像在Internet Explorer、FireFox等軟件中設置代理服務器類似的效果。
代理服務器的功能就是代理網絡用戶去取得網絡信息。我們使用網絡瀏覽器直接連接其他Internet站點取得網絡信息時,通常需要發送Request請求來等到響應。代理服務器是介於瀏覽器和Web服務器之間的一台服務器,有了它之後,瀏覽器不是直接到Web服務器去取得網頁數據而是向代理服務器發出請求,Request請求會先送到代理服務器,由代理服務器來取回瀏覽器所需要的信息並送回給網絡瀏覽器。而且,大部分代理服務器都具有緩衝的功能,就好像一個大的Cache,它有很大的存儲空間,它不斷將新取得的數據儲存到它本機的存儲器上,如果瀏覽器所請求的數據在它本機的存儲器上已經存在而且是最新的,那麼它就不重新從Web服務器取數據,而直接將存儲器上的數據傳送給用戶的瀏覽器,這樣就能顯著提高瀏覽速度和效率。歸納起來代理服務器主要提供如下兩個功能:
突破自身IP限制,對外隱藏自身IP地址。突破IP限制包括訪問國外受限站點,訪問國內特定單位、團體的內部資源。
提高訪問速度,代理服務器提供的緩衝功能可以避免每個用戶都直接訪問遠程主機,從而提高客戶端訪問速度。
17.5.1 直接使用Proxy創建連接
Proxy有如下一個構造器:Proxy(Proxy.Type type, SocketAddress sa):創建表示代理服務器的Proxy對象。而sa參數指定代理服務器的地址,其中type是該代理服務器的類型,該服務器類型有如下三種:
(1)Proxy.Type.DIRECT:表示直接連接或缺少代理。
(2)Proxy.Type.HTTP:表示高級協議的代理,如 HTTP 或 FTP。
(3)Proxy.Type.SOCKS:表示 SOCKS(V4 或 V5)代理。
一旦創建了Proxy對象之後,程序就可以在使用URLConnection打開連接時,或創建Socket連接時傳入一個Proxy對象,作為本次連接所使用的代理服務器。
其中URL包含了一個URLConnection openConnection(Proxy proxy)方法,該方法使用指定的代理服務器來打開連接;而Socket則提供了一個Socket(Proxy proxy)構造器,該構造器使用指定的代理服務器創建一個沒有連接的Socket對象。
下面以URLConnection為例來介紹如何在URLConnection中使用代理服務器。
程序清單:codes/17/17-5/ProxyTest.java
上面代碼第一行粗體字代碼創建了一個Proxy對象,第二行粗體字代碼就是用Proxy對象來打開URLConnection連接。除此之外,該程序的其他地方就是對URLConnection的使用了。由此可見, JDK1.5提供了對代理服務器很好的支持。
17.5.2 使用ProxySelector選擇代理服務器
前面介紹的直接使用Proxy對象可以在打開URLConnection或Socket時指定代理服務器,使用這種方式需要每次打開連接都顯式設置代理服務器。如果想讓系統打開連接時總是具有默認的代理服務器,則可以使用java.net.ProxySelector,它可以它根據不同的連接使用不同的代理服務器。
系統默認的ProxySelector會檢測各種系統屬性和URL協議,然後決定怎樣連接不同的主機。當然,程序也可以調用ProxySelector類的setDefaultI()靜態方法來設置默認代理服務器,也可以調用getDefault()方法獲得系統當前默認的代理服務器。
程序可以通過System類來設置系統的代理服務器屬性,關於代理服務器常用的屬性名有如下三個:
http.proxyHost:設置HTTP訪問所使用的代理服務器地址。該屬性名的前綴可以改為https、ftp等,分別用於設置HTTP訪問、安全HTTP訪問和FTP訪問所用的代理服務器地址。
http.proxyPort:設置HTTP訪問所使用的代理服務器端口。該屬性名的前綴可以改為https、ftp等,分別用於設置HTTP訪問、安全HTTP訪問和FTP訪問所用的代理服務器端口。
http.nonProxyHosts:設置HTTP訪問中不需要使用代理服務器的遠程主機,可以使用*通配符,如果有多個地址,多個地址用豎線(|)分隔。
下面程序示範了通過改變系統屬性來改變默認的代理服務器。
程序清單:codes/17/17-5/ ProxySelectorTest.java
上面程序中三行粗體字代碼設置Java打開HTTP訪問時的代理服務器屬性,其中前兩行代碼設置代理服務器的地址和端口,第三行代碼設置該代理HTTP訪問哪些主機時不需要使用代理服務器。上面程序的①行代碼處直接打開一個URLConnection,但系統會為打開該URLConnection時使用代理服務器。
運行上面程序,將會看到程序長時間等待,因為192.168.0.96通常並不是有效的代理服務器(當然,如果讀者運行的機器恰好可以使用地址為192.168.0.96的代理服務器又另當別論)。
系統提供了默認的ProxySelector子類作為代理選擇器,開發者可以實現自己的代理選擇器,程序可以通過繼承ProxySelector來實現自己的代理選擇器。繼承ProxySelector需要重寫兩個方法:
ListProxy select(URI uri):實現該方法讓代理選擇器根據不同的URI來使用不同的代理服務器,該方法就是代理選擇器管理網絡連接使用代理服務器的關鍵。
connectFailed(URI uri, SocketAddress sa, IOException ioe):當系統通過默認的代理服務器建立連接失敗後,代理選擇器將會自動調用該方法。通過重寫該方法可以對連接代理服務器失敗的情形進行處理。
系統默認的代理服務器選擇器也重寫了connectFailed方法,它重寫該方法的處理策略是:當系統設置的代理服務器失敗時,默認代理選擇器將會採用直連的方式連接遠程資源,所以當運行上面程序等待了足夠長時間時,程序依然可以打印出該遠程資源的所有內容。
Java 編寫IP動態代理
package com.tan.test;
import java.io.BufferedInputStream;
import java.io.IOException;
import java.net.URL;
import java.net.URLConnection;
import org.apache.log4j.Logger;
public class TestProxyIp {
private static final Logger log = Logger.getLogger(TestProxyIp.class);
public static void main(String[] args) throws IOException {
System.setProperty(“http.maxRedirects”, “50”);
System.getProperties().setProperty(“proxySet”, “true”);
// 如果不設置,只要代理IP和代理端口正確,此項不設置也可以
String ip = “59.175.192.126”;
ip = “221.214.180.130”;
ip = “122.224.171.91”;
ip = “58.221.213.166”;
ip = “202.106.16.36”;
ip = “121.8.191.34”;
ip = “222.208.242.30”;
ip = “219.239.90.85”;
ip = “60.31.177.188”;
System.getProperties().setProperty(“http.proxyHost”, ip);
System.getProperties().setProperty(“http.proxyPort”, “3128”);
//確定代理是否設置成功
log.info(getHtml(“”));
//log.info(getHtml(“”));
}
private static String getHtml(String address){
StringBuffer html = new StringBuffer();
String result = null;
try{
URL url = new URL(address);
URLConnection conn = url.openConnection();
conn.setRequestProperty(“User-Agent”,”Mozilla/4.0 (compatible; MSIE 7.0; NT 5.1; GTB5; .NET CLR 2.0.50727; CIBA)”);
BufferedInputStream in = new BufferedInputStream(conn.getInputStream());
try{
String inputLine;
byte[] buf = new byte[4096];
int bytesRead = 0;
while (bytesRead = 0) {
inputLine = new String(buf, 0, bytesRead, “UTF-8”);
/*if (!””.equals(inputLine)) {
System.out.println(inputLine);
}*/
html.append(inputLine);
bytesRead = in.read(buf);
inputLine = null;
}
buf = null;
}finally{
in.close();
conn = null;
url = null;
}
//result = new String(html.toString().trim().getBytes(“ISO-8859-1”), “UTF-8”).toLowerCase();
//result=new String(html.toString().trim().getBytes(“ISO-8859-1”), “GBK”);
}catch (Exception e) {
e.printStackTrace();
return null;
}/*finally{
html = null;
}*/
return html.toString();
}
}
但是找不到有用的動態ip。
原創文章,作者:PCLM,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131103.html