HttpURLConnection总结
生活随笔
收集整理的這篇文章主要介紹了
HttpURLConnection总结
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
URLConnection是個抽象類,它有兩個直接子類分別是HttpURLConnection和JarURLConnection。另外一個重要的類是URL,通常URL可以通過傳給構(gòu)造器一個String類型的參數(shù)來生成一個指向特定地址的URL實(shí)例。每個HttpURLConnection實(shí)例都可用于生成單個請求,但是其他實(shí)例可以透明地共享連接到HTTP服務(wù)器的基礎(chǔ)網(wǎng)絡(luò)。請求后在HttpURLConnection的InputStream或OutputStream上調(diào)用close()方法可以釋放與此實(shí)例關(guān)聯(lián)的網(wǎng)絡(luò)資源,但對共享的持久連接沒有任何影響。如果在調(diào)用disconnect()時持久連接空閑,則可能關(guān)閉基礎(chǔ)套接字。
任何網(wǎng)絡(luò)連接都需要經(jīng)過socket才能連接,HttpURLConnection不需要設(shè)置socket,所以,HttpURLConnection并不是底層的連接,而是在底層連接上的一個請求。這就是為什么HttpURLConneciton只是一個抽象類,自身不能被實(shí)例化的原因。HttpURLConnection只能通過URL.openConnection()方法創(chuàng)建具體的實(shí)例。
雖然底層的網(wǎng)絡(luò)連接可以被多個HttpURLConnection實(shí)例共享,但每一個HttpURLConnection實(shí)例只能發(fā)送一個請求。請求結(jié)束之后,應(yīng)該調(diào)用HttpURLConnection實(shí)例的InputStream或OutputStream的close()方法以釋放請求的網(wǎng)絡(luò)資源,不過這種方式對于持久化連接沒用。對于持久化連接,得用disconnect()方法關(guān)閉底層連接的socket。 1、URLConnection的創(chuàng)建 URLConnection必須要通過url.connection()才能創(chuàng)建URL url = new URL("http://localhost:8893/TestHttpURLConnectionPro/index.jsp");URLConnection urlConnection = url.openConnection();// 此處的urlConnection對象實(shí)際上是根據(jù)URL的// 請求協(xié)議(此處是http)生成的URLConnection類// 的子類HttpURLConnection,故此處最好將其轉(zhuǎn)化// 為HttpURLConnection類型的對象,以便用到// HttpURLConnection更多的API.如下:HttpURLConnection httpUrlConnection = (HttpURLConnection) urlConnection; 2、HttpURLConnection的對象傳參
// 設(shè)置是否向httpUrlConnection輸出,因?yàn)檫@個是post請求,參數(shù)要放在 // http正文內(nèi),因此需要設(shè)為true, 默認(rèn)情況下是false; httpUrlConnection.setDoOutput(true);// 設(shè)置是否從httpUrlConnection讀入,默認(rèn)情況下是true; httpUrlConnection.setDoInput(true);// Post 請求不能使用緩存 httpUrlConnection.setUseCaches(false);// 設(shè)定傳送的內(nèi)容類型是可序列化的java對象 // (如果不設(shè)此項(xiàng),在傳送序列化對象時,當(dāng)WEB服務(wù)默認(rèn)的不是這種類型時可能拋java.io.EOFException) httpUrlConnection.setRequestProperty("Content-type", "application/x-java-serialized-object");// 設(shè)定請求的方法為"POST",默認(rèn)是GET httpUrlConnection.setRequestMethod("POST");// 連接,從上述第2條中url.openConnection()至此的配置必須要在connect之前完成,httpUrlConnection.connect(); 3、HttpURLConnection連接問題
// 此處getOutputStream會隱含的進(jìn)行connect(即:如同調(diào)用上面的connect()方法, // 所以在開發(fā)中不調(diào)用上述的connect()也可以)。 OutputStream outStrm = httpUrlConnection.getOutputStream(); 4、 HttpURLConnection寫數(shù)據(jù)與發(fā)送數(shù)據(jù)問題
// 現(xiàn)在通過輸出流對象構(gòu)建對象輸出流對象,以實(shí)現(xiàn)輸出可序列化的對象。 ObjectOutputStream objOutputStrm = new ObjectOutputStream(outStrm);// 向?qū)ο筝敵隽鲗懗鰯?shù)據(jù),這些數(shù)據(jù)將存到內(nèi)存緩沖區(qū)中 objOutputStrm.writeObject(new String("我是測試數(shù)據(jù)"));// 刷新對象輸出流,將任何字節(jié)都寫入潛在的流中(些處為ObjectOutputStream) objOutputStm.flush();// 關(guān)閉流對象。此時,不能再向?qū)ο筝敵隽鲗懭肴魏螖?shù)據(jù),先前寫入的數(shù)據(jù)存在于內(nèi)存緩沖區(qū)中, // 在調(diào)用下邊的getInputStream()函數(shù)時才把準(zhǔn)備好的http請求正式發(fā)送到服務(wù)器 objOutputStm.close();// 調(diào)用HttpURLConnection連接對象的getInputStream()函數(shù), // 將內(nèi)存緩沖區(qū)中封裝好的完整的HTTP請求電文發(fā)送到服務(wù)端。 InputStream inStrm = httpConn.getInputStream(); // <===注意,實(shí)際發(fā)送請求的代碼段就在這里// 上邊的httpConn.getInputStream()方法已調(diào)用,本次HTTP請求已結(jié)束,下邊向?qū)ο筝敵隽鞯妮敵鲆褵o意義, // 既使對象輸出流沒有調(diào)用close()方法,下邊的操作也不會向?qū)ο筝敵隽鲗懭肴魏螖?shù)據(jù). // 因此,要重新發(fā)送數(shù)據(jù)時需要重新創(chuàng)建連接、重新設(shè)參數(shù)、重新創(chuàng)建流對象、重新寫數(shù)據(jù)、 // 重新發(fā)送數(shù)據(jù)(至于是否不用重新這些操作需要再研究) objOutputStm.writeObject(new String("")); httpConn.getInputStream(); 5、HttpURLConnection是基于HTTP協(xié)議的,其底層通過socket通信實(shí)現(xiàn)。如果不設(shè)置超時(timeout),在網(wǎng)絡(luò)異常的情況下,可能會導(dǎo)致程序僵死而不繼續(xù)往下執(zhí)行??梢酝ㄟ^以下兩個語句來設(shè)置相應(yīng)的超時: System.setProperty("sun.net.client.defaultConnectTimeout", 超時毫秒數(shù)字符串); System.setProperty("sun.net.client.defaultReadTimeout", 超時毫秒數(shù)字符串); 其中: sun.net.client.defaultConnectTimeout:連接主機(jī)的超時時間(單位:毫秒) sun.net.client.defaultReadTimeout:從主機(jī)讀取數(shù)據(jù)的超時時間(單位:毫秒) 例如: System.setProperty("sun.net.client.defaultConnectTimeout", "60000"); System.setProperty("sun.net.client.defaultReadTimeout", "60000"); JDK 1.5以前的版本,只能通過設(shè)置這兩個系統(tǒng)屬性來控制網(wǎng)絡(luò)超時。在1.5中,還可以使用HttpURLConnection的父類URLConnection的以下兩個方法: setConnectTimeout:設(shè)置連接主機(jī)超時(單位:毫秒) setReadTimeout:設(shè)置從主機(jī)讀取數(shù)據(jù)超時(單位:毫秒) 例如: HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); urlCon.setConnectTimeout(60000); urlCon.setReadTimeout(60000); 6、一些常用方法 設(shè)置連接參數(shù)的方法: setAllowUserInteraction setDoInput setDoOutput setIfModifiedSince setUseCaches setDefaultAllowUserInteraction setDefaultUseCaches 設(shè)置請求頭和響應(yīng)頭: HTTP請求允許一個key帶多個用逗號分開的values,但是HttpURLConnection只提供了單個操作的方法: setRequestProperty(key,value) addRequestProperty(key,value) setRequestProperty和addRequestProperty的區(qū)別就是,setRequestProperty會覆蓋已經(jīng)存在的key的所有values,有清零重新賦值的作用。而addRequestProperty則是在原來key的基礎(chǔ)上繼續(xù)添加其他value。 發(fā)送URL請求: 建立實(shí)際連接之后,就是發(fā)送請求,把請求參數(shù)傳到服務(wù)器,這就需要使用outputStream把請求參數(shù)傳給服務(wù)器:getOutputStream 獲取響應(yīng): 請求發(fā)送成功之后,即可獲取響應(yīng)的狀態(tài)碼,如果成功既可以讀取響應(yīng)中的數(shù)據(jù),獲取這些數(shù)據(jù)的方法包括 getContent getHeaderField getInputStream 對于大部分請求來說,getInputStream和getContent是用的最多的。 相應(yīng)的信息頭用以下方法獲取: getContentEncoding getContentLength getContentType getDate getExpiration getLastModifedHttpURLConnection在線API
任何網(wǎng)絡(luò)連接都需要經(jīng)過socket才能連接,HttpURLConnection不需要設(shè)置socket,所以,HttpURLConnection并不是底層的連接,而是在底層連接上的一個請求。這就是為什么HttpURLConneciton只是一個抽象類,自身不能被實(shí)例化的原因。HttpURLConnection只能通過URL.openConnection()方法創(chuàng)建具體的實(shí)例。
雖然底層的網(wǎng)絡(luò)連接可以被多個HttpURLConnection實(shí)例共享,但每一個HttpURLConnection實(shí)例只能發(fā)送一個請求。請求結(jié)束之后,應(yīng)該調(diào)用HttpURLConnection實(shí)例的InputStream或OutputStream的close()方法以釋放請求的網(wǎng)絡(luò)資源,不過這種方式對于持久化連接沒用。對于持久化連接,得用disconnect()方法關(guān)閉底層連接的socket。 1、URLConnection的創(chuàng)建 URLConnection必須要通過url.connection()才能創(chuàng)建URL url = new URL("http://localhost:8893/TestHttpURLConnectionPro/index.jsp");URLConnection urlConnection = url.openConnection();// 此處的urlConnection對象實(shí)際上是根據(jù)URL的// 請求協(xié)議(此處是http)生成的URLConnection類// 的子類HttpURLConnection,故此處最好將其轉(zhuǎn)化// 為HttpURLConnection類型的對象,以便用到// HttpURLConnection更多的API.如下:HttpURLConnection httpUrlConnection = (HttpURLConnection) urlConnection; 2、HttpURLConnection的對象傳參
// 設(shè)置是否向httpUrlConnection輸出,因?yàn)檫@個是post請求,參數(shù)要放在 // http正文內(nèi),因此需要設(shè)為true, 默認(rèn)情況下是false; httpUrlConnection.setDoOutput(true);// 設(shè)置是否從httpUrlConnection讀入,默認(rèn)情況下是true; httpUrlConnection.setDoInput(true);// Post 請求不能使用緩存 httpUrlConnection.setUseCaches(false);// 設(shè)定傳送的內(nèi)容類型是可序列化的java對象 // (如果不設(shè)此項(xiàng),在傳送序列化對象時,當(dāng)WEB服務(wù)默認(rèn)的不是這種類型時可能拋java.io.EOFException) httpUrlConnection.setRequestProperty("Content-type", "application/x-java-serialized-object");// 設(shè)定請求的方法為"POST",默認(rèn)是GET httpUrlConnection.setRequestMethod("POST");// 連接,從上述第2條中url.openConnection()至此的配置必須要在connect之前完成,httpUrlConnection.connect(); 3、HttpURLConnection連接問題
// 此處getOutputStream會隱含的進(jìn)行connect(即:如同調(diào)用上面的connect()方法, // 所以在開發(fā)中不調(diào)用上述的connect()也可以)。 OutputStream outStrm = httpUrlConnection.getOutputStream(); 4、 HttpURLConnection寫數(shù)據(jù)與發(fā)送數(shù)據(jù)問題
// 現(xiàn)在通過輸出流對象構(gòu)建對象輸出流對象,以實(shí)現(xiàn)輸出可序列化的對象。 ObjectOutputStream objOutputStrm = new ObjectOutputStream(outStrm);// 向?qū)ο筝敵隽鲗懗鰯?shù)據(jù),這些數(shù)據(jù)將存到內(nèi)存緩沖區(qū)中 objOutputStrm.writeObject(new String("我是測試數(shù)據(jù)"));// 刷新對象輸出流,將任何字節(jié)都寫入潛在的流中(些處為ObjectOutputStream) objOutputStm.flush();// 關(guān)閉流對象。此時,不能再向?qū)ο筝敵隽鲗懭肴魏螖?shù)據(jù),先前寫入的數(shù)據(jù)存在于內(nèi)存緩沖區(qū)中, // 在調(diào)用下邊的getInputStream()函數(shù)時才把準(zhǔn)備好的http請求正式發(fā)送到服務(wù)器 objOutputStm.close();// 調(diào)用HttpURLConnection連接對象的getInputStream()函數(shù), // 將內(nèi)存緩沖區(qū)中封裝好的完整的HTTP請求電文發(fā)送到服務(wù)端。 InputStream inStrm = httpConn.getInputStream(); // <===注意,實(shí)際發(fā)送請求的代碼段就在這里// 上邊的httpConn.getInputStream()方法已調(diào)用,本次HTTP請求已結(jié)束,下邊向?qū)ο筝敵隽鞯妮敵鲆褵o意義, // 既使對象輸出流沒有調(diào)用close()方法,下邊的操作也不會向?qū)ο筝敵隽鲗懭肴魏螖?shù)據(jù). // 因此,要重新發(fā)送數(shù)據(jù)時需要重新創(chuàng)建連接、重新設(shè)參數(shù)、重新創(chuàng)建流對象、重新寫數(shù)據(jù)、 // 重新發(fā)送數(shù)據(jù)(至于是否不用重新這些操作需要再研究) objOutputStm.writeObject(new String("")); httpConn.getInputStream(); 5、HttpURLConnection是基于HTTP協(xié)議的,其底層通過socket通信實(shí)現(xiàn)。如果不設(shè)置超時(timeout),在網(wǎng)絡(luò)異常的情況下,可能會導(dǎo)致程序僵死而不繼續(xù)往下執(zhí)行??梢酝ㄟ^以下兩個語句來設(shè)置相應(yīng)的超時: System.setProperty("sun.net.client.defaultConnectTimeout", 超時毫秒數(shù)字符串); System.setProperty("sun.net.client.defaultReadTimeout", 超時毫秒數(shù)字符串); 其中: sun.net.client.defaultConnectTimeout:連接主機(jī)的超時時間(單位:毫秒) sun.net.client.defaultReadTimeout:從主機(jī)讀取數(shù)據(jù)的超時時間(單位:毫秒) 例如: System.setProperty("sun.net.client.defaultConnectTimeout", "60000"); System.setProperty("sun.net.client.defaultReadTimeout", "60000"); JDK 1.5以前的版本,只能通過設(shè)置這兩個系統(tǒng)屬性來控制網(wǎng)絡(luò)超時。在1.5中,還可以使用HttpURLConnection的父類URLConnection的以下兩個方法: setConnectTimeout:設(shè)置連接主機(jī)超時(單位:毫秒) setReadTimeout:設(shè)置從主機(jī)讀取數(shù)據(jù)超時(單位:毫秒) 例如: HttpURLConnection urlCon = (HttpURLConnection)url.openConnection(); urlCon.setConnectTimeout(60000); urlCon.setReadTimeout(60000); 6、一些常用方法 設(shè)置連接參數(shù)的方法: setAllowUserInteraction setDoInput setDoOutput setIfModifiedSince setUseCaches setDefaultAllowUserInteraction setDefaultUseCaches 設(shè)置請求頭和響應(yīng)頭: HTTP請求允許一個key帶多個用逗號分開的values,但是HttpURLConnection只提供了單個操作的方法: setRequestProperty(key,value) addRequestProperty(key,value) setRequestProperty和addRequestProperty的區(qū)別就是,setRequestProperty會覆蓋已經(jīng)存在的key的所有values,有清零重新賦值的作用。而addRequestProperty則是在原來key的基礎(chǔ)上繼續(xù)添加其他value。 發(fā)送URL請求: 建立實(shí)際連接之后,就是發(fā)送請求,把請求參數(shù)傳到服務(wù)器,這就需要使用outputStream把請求參數(shù)傳給服務(wù)器:getOutputStream 獲取響應(yīng): 請求發(fā)送成功之后,即可獲取響應(yīng)的狀態(tài)碼,如果成功既可以讀取響應(yīng)中的數(shù)據(jù),獲取這些數(shù)據(jù)的方法包括 getContent getHeaderField getInputStream 對于大部分請求來說,getInputStream和getContent是用的最多的。 相應(yīng)的信息頭用以下方法獲取: getContentEncoding getContentLength getContentType getDate getExpiration getLastModifedHttpURLConnection在線API
總結(jié)
以上是生活随笔為你收集整理的HttpURLConnection总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HTTPClient系统学习
- 下一篇: 【Spring学习】RestTempla