Android Studio的網路連線HttpURLConnection失效
Android Studio的網路連線HttpURLConnection.
首先,應該考慮是不是許可權問題,先檢查Manifest.xml看是否配置了許可權,如果沒有配置,則在application前面加上:
如果還不行,那可能是Android版本問題,需要在用HttpURLConnection的方法裡面加上:
[java] view plain copy
StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build());
例如:
[java] view plain copy
/**
* 獲取網路圖片的資料
* @param path 網路圖片路徑
* @return
*/
public static byte[] getImage(String path) throws Exception{
URL url = new URL(path);
StrictMode.setThreadPolicy(new StrictMode.ThreadPolicy.Builder().detectDiskReads().detectDiskWrites().detectNetwork().penaltyLog().build());
HttpURLConnection conn = (HttpURLConnection) url.openConnection();//基於HTTP協議連線物件
conn.setConnectTimeout(8000);
conn.setRequestMethod(“GET”);
if(conn.getResponseCode()==200){
InputStream inStream = conn.getInputStream();
return StreamUtility.read(inStream);
}
return null;
}
附http狀態碼:
http狀態返回程式碼 1xx(臨時響應)
表示臨時響應並需要請求者繼續執行操作的狀態程式碼。
http狀態返回程式碼 程式碼 說明
100 (繼續) 請求者應當繼續提出請求。 伺服器返回此程式碼表示已收到請求的第一部分,正在等待其餘部分。
101 (切換協議) 請求者已要求伺服器切換協議,伺服器已確認並準備切換。
http狀態返回程式碼 2xx (成功)
表示成功處理了請求的狀態程式碼。
http狀態返回程式碼 程式碼 說明
200 (成功) 伺服器已成功處理了請求。 通常,這表示伺服器提供了請求的網頁。
201 (已建立) 請求成功並且伺服器建立了新的資源。
202 (已接受) 伺服器已接受請求,但尚未處理。
203 (非授權資訊) 伺服器已成功處理了請求,但返回的資訊可能來自另一來源。
204 (無內容) 伺服器成功處理了請求,但沒有返回任何內容。
205 (重置內容) 伺服器成功處理了請求,但沒有返回任何內容。
206 (部分內容) 伺服器成功處理了部分 GET 請求。
http狀態返回程式碼 3xx (重定向)
表示要完成請求,需要進一步操作。 通常,這些狀態程式碼用來重定向。
http狀態返回程式碼 程式碼 說明
300 (多種選擇) 針對請求,伺服器可執行多種操作。 伺服器可根據請求者 (user agent) 選擇一項操作,或提供操作列表供請求者選擇。
301 (永久移動) 請求的網頁已永久移動到新位置。 伺服器返回此響應(對 GET 或 HEAD 請求的響應)時,會自動將請求者轉到新位置。
302 (臨時移動) 伺服器目前從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。
303 (檢視其他位置) 請求者應當對不同的位置使用單獨的 GET 請求來檢索響應時,伺服器返回此程式碼。
304 (未修改) 自從上次請求後,請求的網頁未修改過。 伺服器返回此響應時,不會返回網頁內容。
305 (使用代理) 請求者只能使用代理訪問請求的網頁。 如果伺服器返回此響應,還表示請求者應使用代理。
307 (臨時重定向) 伺服器目前從不同位置的網頁響應請求,但請求者應繼續使用原有位置來進行以後的請求。
http狀態返回程式碼 4xx(請求錯誤)
這些狀態程式碼表示請求可能出錯,妨礙了伺服器的處理。
http狀態返回程式碼 程式碼 說明
400 (錯誤請求) 伺服器不理解請求的語法。
401 (未授權) 請求要求身份驗證。 對於需要登入的網頁,伺服器可能返回此響應。
403 (禁止) 伺服器拒絕請求。
404 (未找到) 伺服器找不到請求的網頁。
405 (方法禁用) 禁用請求中指定的方法。
406 (不接受) 無法使用請求的內容特性響應請求的網頁。
407 (需要代理授權) 此狀態程式碼與 401(未授權)類似,但指定請求者應當授權使用代理。
408 (請求超時) 伺服器等候請求時發生超時。
409 (衝突) 伺服器在完成請求時發生衝突。 伺服器必須在響應中包含有關衝突的資訊。
410 (已刪除) 如果請求的資源已永久刪除,伺服器就會返回此響應。
411 (需要有效長度) 伺服器不接受不含有效內容長度標頭欄位的請求。
412 (未滿足前提條件) 伺服器未滿足請求者在請求中設定的其中一個前提條件。
413 (請求實體過大) 伺服器無法處理請求,因為請求實體過大,超出伺服器的處理能力。
414 (請求的 URI 過長) 請求的 URI(通常為網址)過長,伺服器無法處理。
415 (不支援的媒體型別) 請求的格式不受請求頁面的支援。
416 (請求範圍不符合要求) 如果頁面無法提供請求的範圍,則伺服器會返回此狀態程式碼。
417 (未滿足期望值) 伺服器未滿足”期望”請求標頭欄位的要求。
http狀態返回程式碼 5xx(伺服器錯誤)
這些狀態程式碼表示伺服器在嘗試處理請求時發生內部錯誤。 這些錯誤可能是伺服器本身的錯誤,而不是請求出錯。
http狀態返回程式碼 程式碼 說明
500 (伺服器內部錯誤) 伺服器遇到錯誤,無法完成請求。
501 (尚未實施) 伺服器不具備完成請求的功能。 例如,伺服器無法識別請求方法時可能會返回此程式碼。
502 (錯誤閘道器) 伺服器作為閘道器或代理,從上游伺服器收到無效響應。
503 (服務不可用) 伺服器目前無法使用(由於超載或停機維護)。 通常,這只是暫時狀態。
504 (閘道器超時) 伺服器作為閘道器或代理,但是沒有及時從上游伺服器收到請求。
505 (HTTP 版本不受支援) 伺服器不支援請求中所用的 HTTP 協議版本。
一些常見的http狀態返回程式碼為:
200 - 伺服器成功返回網頁
404 - 請求的網頁不存在
503 - 服務不可用
最後排除所有可能,結果居然是因為主執行緒裡面直接呼叫網路請求,android已經不在支援。
這個請求在jar裡面沒被發現。好多年不搞android,真是忘得差不多了。
呼叫jar一定要注意裡面的網路請求是不是非同步的。