欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中Http連接的兩種方式(小結(jié))

 更新時(shí)間:2019年09月05日 15:02:13   作者:一路風(fēng)順  
這篇文章主要介紹了Java中Http連接的兩種方式(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在java中連接http,介紹兩種方法,一種是java的HttpUrlConnection,另一種是apacha公司的httpClient,后者是第三方的類(lèi)庫(kù)需要從外部,導(dǎo)入,同時(shí)這也是第一次使用外部的類(lèi)庫(kù),以后還會(huì)有很多需要導(dǎo)入外部類(lèi)庫(kù)的需求。
http協(xié)議是基于tcp的一種協(xié)議。
tcp是一種保證可靠連接的傳輸協(xié)議,通過(guò)三次握手,和丟失重傳的機(jī)制保證數(shù)據(jù)的傳輸。

首先來(lái)看HttpUrlConnection

這個(gè)類(lèi)是java自帶的,直接import就行。
使用tcp連接的過(guò)程幾乎都一樣,http協(xié)議中有兩種方式,一種是get方式,另一種是post提交,有些網(wǎng)頁(yè)需要提交數(shù)據(jù),所以要使用。

先看GET

首先需要一個(gè)url,這個(gè)url使用String建立

String path ="";//
URL url = new URL(path);

之后通過(guò)url對(duì)象打開(kāi)連接

HttpURLConnection conn = (HttpURLConnection) url.openConnection();

這里需要注意打開(kāi)連接之后,這個(gè)函數(shù)返回的是不是httpUrlconnection類(lèi)型而是 URLConnection類(lèi)型,可以直接強(qiáng)轉(zhuǎn)。
之后開(kāi)始通過(guò)對(duì)conn對(duì)象進(jìn)行設(shè)置連接的參數(shù)

conn.setRequestMethod("GET");  //設(shè)置本次請(qǐng)求的方式 , 默認(rèn)是GET方式, 參數(shù)要求都是大寫(xiě)字母
      conn.setConnectTimeout(5000);//設(shè)置連接超時(shí)
      conn.setDoInput(true);//是否打開(kāi)輸入流 , 此方法默認(rèn)為true
      conn.setDoOutput(true);//是否打開(kāi)輸出流, 此方法默認(rèn)為false
      conn.connect();//表示連接

之后就開(kāi)始判斷是否連接成功,服務(wù)器會(huì)返回一個(gè)響應(yīng)碼,最常見(jiàn)的大概就是我們的404,不過(guò)除此之外還有很多,而成功連接返回的是200,也有一個(gè)靜態(tài)的名稱(chēng)來(lái)代替HTTP_OK。

可以使用一個(gè)if判斷:
int code = conn.getResponseCode();

當(dāng)我們確定連接成功之后,我們就需要打開(kāi)服務(wù)器的輸出流,然后從這個(gè)流里讀取數(shù)據(jù)

  InputStream is = conn.getInputStream();

        String name = path.substring(path.lastIndexOf("/")+1);

        System.out.println("name = " + name);

        fos = new FileOutputStream("C:\\pro\\"+name);

        byte[] buffer = new byte[1024];
        int len = 0;

        while ((len = is.read(buffer))!=-1) {

          fos.write(buffer, 0, len);

這里通過(guò)getinputStream得到流,然后通過(guò)FileOutputStream流將文件寫(xiě)入到c盤(pán)。至此下載文件結(jié)束。

下面是post

與get相比,就是在設(shè)置請(qǐng)求方式的時(shí)候設(shè)置為POST,然后提交要提交的數(shù)據(jù)

OutputStream os = conn.getOutputStream();
    os.write("platform=2&appVersion=1.7.0&osType=2".getBytes());
    os.flush();

得到了服務(wù)器的輸出流,然后寫(xiě)入數(shù)據(jù),以&分隔。
除此之外,完全一樣。

HttpClient

首先我們需要導(dǎo)入第三方的類(lèi)庫(kù)
第一部肯定是需要下載HttpClient的jar包。

這里寫(xiě)圖片描述 

得到像這樣的3個(gè)jar包,然后再項(xiàng)目中新建一個(gè)libs的文件夾,將這三個(gè)jar包復(fù)制進(jìn)去

這里寫(xiě)圖片描述 

選中這三個(gè)包,然后右鍵,點(diǎn)擊Bulid Path就可以了
導(dǎo)入了包之后,就可以使用HttpClient類(lèi)了
首先還是需要一個(gè)url

String path = "";

然后創(chuàng)建一個(gè)HttpClient對(duì)象

HttpClient client = new DefaultHttpClient();

之后創(chuàng)建一個(gè)GET請(qǐng)求對(duì)象

HttpGet httpGet = new HttpGet(path);

之后通過(guò)Client的execute函數(shù)來(lái)連接

HttpResponse response = client.execute(httpGet);

參數(shù)是get請(qǐng)求對(duì)象,返回的是一個(gè)httpresponse對(duì)象,這個(gè)對(duì)象,就是我們得到得結(jié)果,然后我們對(duì)這個(gè)response操作
同樣,先判斷一下響應(yīng)碼

response.getStatusLine().getStatusCode() == 200;

這里首先得到狀態(tài)行,然后再得到里面的狀態(tài)碼。
我們通過(guò)這個(gè)Response可以得到一個(gè)實(shí)體HttpEntity。

HttpEntity entity = response.getEntity();

從這個(gè)實(shí)體中我們可以像上面一樣得到一個(gè)流使用getContent(),不過(guò),這個(gè)類(lèi)為我們提供了更加簡(jiǎn)單的方法,在EntityUtils類(lèi)中有toByteArray(entity),和toString(entity)方法,返回的分別是byte[],和string,對(duì)于byte數(shù)組,我們可以使用FileOutputStream來(lái)寫(xiě)入文件流中。

Post方式

和上面一樣,只是多出了一些操作部分

HttpPost httpPost = new HttpPost(path);

    //創(chuàng)建一個(gè)提交數(shù)據(jù)的容器
    List<BasicNameValuePair> parames = new ArrayList<>();

    parames.add(new BasicNameValuePair("platform", "2"));
    parames.add(new BasicNameValuePair("appVersion", "1.7.0"));
    parames.add(new BasicNameValuePair("osType", "2"));

    //封裝容器到請(qǐng)求參數(shù)中
    HttpEntity entity = new UrlEncodedFormEntity(parames);
    //設(shè)置請(qǐng)求參數(shù)到post請(qǐng)求中
    httpPost.setEntity(entity);

    //執(zhí)行post請(qǐng)求
    HttpResponse response = client.execute(httpPost);

這里的的類(lèi)型變成了HttpPost,然后將post的參數(shù)加到容器里,然后將容器傳給一個(gè)實(shí)體,將這個(gè)請(qǐng)求給post,之后執(zhí)行。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • java自帶的工具Jstack截取進(jìn)程中的堆棧信息

    java自帶的工具Jstack截取進(jìn)程中的堆棧信息

    本文給大家記錄的是java自帶的工具Jstack截取進(jìn)程中的堆棧信息的方法,非常的實(shí)用,有需要的小伙伴可以參考下。
    2016-01-01
  • java開(kāi)發(fā)微信公眾號(hào)支付

    java開(kāi)發(fā)微信公眾號(hào)支付

    這篇文章主要給大家結(jié)合微信支付接口開(kāi)發(fā)的實(shí)踐,從獲取用戶授權(quán)到各主要接口的使用方法等方面介紹微信支付的關(guān)鍵點(diǎn)技術(shù),有需要的小伙伴可以參考下
    2015-08-08
  • Java中數(shù)組的使用與注意事項(xiàng)詳解(推薦)

    Java中數(shù)組的使用與注意事項(xiàng)詳解(推薦)

    數(shù)組是一組地址連續(xù)、長(zhǎng)度固定的具有相同類(lèi)型的數(shù)據(jù)的集合,通過(guò)數(shù)組下標(biāo)我們可以指定數(shù)字中的每一個(gè)元素,下面這篇文章主要給大家介紹了關(guān)于Java中數(shù)組的使用與注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下
    2021-08-08
  • 淺談java調(diào)用Restful API接口的方式

    淺談java調(diào)用Restful API接口的方式

    這篇文章主要介紹了淺談java調(diào)用Restful API接口的方式,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • Java中對(duì)List去重 Stream去重的解決方法

    Java中對(duì)List去重 Stream去重的解決方法

    這篇文章主要介紹了Java中對(duì)List去重, Stream去重的問(wèn)題解答,文中給大家介紹了Java中List集合去除重復(fù)數(shù)據(jù)的方法,需要的朋友可以參考下
    2018-04-04
  • spring-retry簡(jiǎn)單使用方法

    spring-retry簡(jiǎn)單使用方法

    這篇文章主要介紹了spring-retry簡(jiǎn)單使用方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Java 生成隨機(jī)單據(jù)號(hào)的實(shí)現(xiàn)示例

    Java 生成隨機(jī)單據(jù)號(hào)的實(shí)現(xiàn)示例

    本文主要介紹了Java 生成隨機(jī)單據(jù)號(hào)的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-09-09
  • Spring七大組件是哪些以及作用

    Spring七大組件是哪些以及作用

    這篇文章主要介紹了Spring七大組件是哪些以及作用,幫助剛接觸spring的朋友更快理解,如果有說(shuō)的不對(duì)的地方還請(qǐng)指正,需要的朋友可以參考下
    2023-03-03
  • 解決try-catch捕獲異常信息后Spring事務(wù)失效的問(wèn)題

    解決try-catch捕獲異常信息后Spring事務(wù)失效的問(wèn)題

    這篇文章主要介紹了解決try-catch捕獲異常信息后Spring事務(wù)失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java基礎(chǔ)之刪除文本文件中特定行的內(nèi)容

    Java基礎(chǔ)之刪除文本文件中特定行的內(nèi)容

    這篇文章主要介紹了Java基礎(chǔ)之刪除文本文件中特定行的內(nèi)容,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04

最新評(píng)論