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

Java發(fā)送http請求的示例(get與post方法請求)

 更新時間:2021年01月04日 09:43:38   作者:劃水De雁曉明  
這篇文章主要介紹了Java發(fā)送http請求的示例(get與post方法請求),幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
package com.jiucool.www.struts.action;

 import java.io.BufferedReader;
 import java.io.DataOutputStream;
 import java.io.File;
 import java.io.FileReader;
 import java.io.IOException;
 import java.io.InputStreamReader;
 import java.net.HttpURLConnection;
 import java.net.URL;
 import java.net.URLEncoder;

public class post_request {
  public static final String GET_URL = "http://www.cngolon.com/request.action?key=j0r56u2";
  public static final String POST_URL = "http://www.cngolon.com/request.action";
  //get()請求
  public static void readContentFromGet() throws IOException {
    // 拼湊get請求的URL字串,使用URLEncoder.encode對特殊和不可見字符進行編碼
    String getURL =
      GET_URL + "&activatecode=" + URLEncoder.encode("中國聚龍", "utf-8");
    URL getUrl = new URL(getURL);
    // 根據(jù)拼湊的URL,打開連接,URL.openConnection函數(shù)會根據(jù)URL的類型,
    // 返回不同的URLConnection子類的對象,這里URL是一個http,因此實際返回的是HttpURLConnection
    HttpURLConnection connection = (HttpURLConnection) getUrl.openConnection();
    // 進行連接,但是實際上get request要在下一句的connection.getInputStream()函數(shù)中才會真正發(fā)到
    // 服務(wù)器
    connection.connect();
    // 取得輸入流,并使用Reader讀取
    BufferedReader reader = new BufferedReader(
      new InputStreamReader(connection.getInputStream(), "utf-8")
    );
    //設(shè)置編碼,否則中文亂碼
    System.out.println("=============================");
    System.out.println("Contents of get request");
    System.out.println("=============================");
    String lines;
    while ((lines = reader.readLine()) != null) {
      //lines = new String(lines.getBytes(), "utf-8");
      System.out.println(lines);
    }
    reader.close();
    // 斷開連接
    connection.disconnect();
    System.out.println("=============================");
    System.out.println("Contents of get request ends");
    System.out.println("=============================");
  }
  //post()請求
  public static void readContentFromPost() throws IOException {
    // Post請求的url,與get不同的是不需要帶參數(shù)
    URL postUrl = new URL(POST_URL);
    // 打開連接
    HttpURLConnection connection = (HttpURLConnection) postUrl.openConnection();
    // Output to the connection. Default is
    // false, set to true because post
    // method must write something to the
    // connection
    // 設(shè)置是否向connection輸出,因為這個是post請求,參數(shù)要放在
    // http正文內(nèi),因此需要設(shè)為true
    connection.setDoOutput(true);
    // Read from the connection. Default is true.
    connection.setDoInput(true);
    // Set the post method. Default is GET
    connection.setRequestMethod("POST");
    // Post cannot use caches
    // Post 請求不能使用緩存
    connection.setUseCaches(false);
    // This method takes effects to
    // every instances of this class.
    // URLConnection.setFollowRedirects是static函數(shù),作用于所有的URLConnection對象。
    // connection.setFollowRedirects(true);
    // This methods only
    // takes effacts to this
    // instance.
    // URLConnection.setInstanceFollowRedirects是成員函數(shù),僅作用于當(dāng)前函數(shù)
    connection.setInstanceFollowRedirects(true);
    // Set the content type to urlencoded,
    // because we will write
    // some URL-encoded content to the
    // connection. Settings above must be set before connect!
    // 配置本次連接的Content-type,配置為application/x-www-form-urlencoded的
    // 意思是正文是urlencoded編碼過的form參數(shù),下面我們可以看到我們對正文內(nèi)容使用URLEncoder.encode
    // 進行編碼
    connection.setRequestProperty(
      "Content-Type",
      "application/x-www-form-urlencoded"
    );
    // 連接,從postUrl.openConnection()至此的配置必須要在connect之前完成,
    // 要注意的是connection.getOutputStream會隱含的進行connect。
    connection.connect();
    DataOutputStream out = new DataOutputStream(connection.getOutputStream());
    // The URL-encoded contend
    // 正文,正文內(nèi)容其實跟get的URL中'?'后的參數(shù)字符串一致
    String content =
      "key=j0r53nmbbd78x7m1pqml06u2&type=1&toemail=cngolon@gmail.com" +
      "&activatecode=" +
      URLEncoder.encode("中國聚龍", "utf-8");
    // DataOutputStream.writeBytes將字符串中的16位的unicode字符以8位的字符形式寫道流里面
    out.writeBytes(content);
    out.flush();
    out.close();
    // flush and close
    BufferedReader reader = new BufferedReader(
      new InputStreamReader(connection.getInputStream(), "utf-8")
    );
    //設(shè)置編碼,否則中文亂碼
    String line = "";
    System.out.println("=============================");
    System.out.println("Contents of post request");
    System.out.println("=============================");
    while ((line = reader.readLine()) != null) {
      //line = new String(line.getBytes(), "utf-8");
      System.out.println(line);
    }
    System.out.println("=============================");
    System.out.println("Contents of post request ends");
    System.out.println("=============================");
    reader.close();
    connection.disconnect();
  }
}

    HttpURLConnection.connect函數(shù),實際上只是建立了一個與服務(wù)器的tcp連接,并沒有實際發(fā)送http請求。無論是post還是get,http請求實際上直到HttpURLConnection.getInputStream()這個函數(shù)里面才正式發(fā)送出去。

    在readContentFromPost()中,順序是重中之重,對connection對象的一切配置(那一堆set函數(shù))都必須要在connect()函數(shù)執(zhí)行之前完成。而對outputStream的寫操作,又必須要在inputStream的讀操作之前。這些順序?qū)嶋H上是由http請求的格式?jīng)Q定的。

    http請求實際上由兩部分組成,一個是http頭,所有關(guān)于此次http請求的配置都在http頭里面定義,一個是正文content,在connect()函數(shù)里面,會根據(jù)HttpURLConnection對象的配置值生成http頭,因此在調(diào)用connect函數(shù)之前,就必須把所有的配置準備好。

    緊接著http頭的是http請求的正文,正文的內(nèi)容通過outputStream寫入,實際上outputStream不是一個網(wǎng)絡(luò)流,充其量是個字符串流,往里面寫入的東西不會立即發(fā)送到網(wǎng)絡(luò),而是在流關(guān)閉后,根據(jù)輸入的內(nèi)容生成http正文。

    至此,http請求的東西已經(jīng)準備就緒。在getInputStream()函數(shù)調(diào)用的時候,就會把準備好的http請求正式發(fā)送到服務(wù)器了,然后返回一個輸入流,用于讀取服務(wù)器對于此次http請求的返回信息。由于http請求在getInputStream的時候已經(jīng)發(fā)送出去了(包括http頭和正文),因此在getInputStream()函數(shù)之后對connection對象進行設(shè)置(對http頭的信息進行修改)或者寫入outputStream(對正文進行修改)都是沒有意義的了,執(zhí)行這些操作會導(dǎo)致異常的發(fā)生。

以上就是Java發(fā)送http請求的示例(get與post方法請求)的詳細內(nèi)容,更多關(guān)于Java發(fā)送http請求的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Spring Boot整合Mybatis并完成CRUD操作的實現(xiàn)示例

    Spring Boot整合Mybatis并完成CRUD操作的實現(xiàn)示例

    這篇文章主要介紹了Spring Boot整合Mybatis并完成CRUD操作的實現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • SpringBoot查詢PGSQL分表后的數(shù)據(jù)的代碼示例

    SpringBoot查詢PGSQL分表后的數(shù)據(jù)的代碼示例

    數(shù)據(jù)庫用的pgsql,在表數(shù)據(jù)超過100w條的時候執(zhí)行定時任務(wù)進行了分表,分表后表名命名為原的表名后面拼接時間,但是我在java業(yè)務(wù)代碼中,我想查詢之前的那條數(shù)據(jù)就查不到了,本文給大家介紹了SpringBoot中如何查詢PGSQL分表后的數(shù)據(jù),需要的朋友可以參考下
    2024-05-05
  • Spring中的spring-retry重試機制解析

    Spring中的spring-retry重試機制解析

    這篇文章主要介紹了Spring中的spring-retry重試機制解析,spring-retry可以通過注解,在不入侵原有業(yè)務(wù)邏輯代碼的方式下,優(yōu)雅的實現(xiàn)重處理功能,在spring-retry中,所有配置都是基于簡單注釋的,需要的朋友可以參考下
    2024-01-01
  • 深入理解Java設(shè)計模式之外觀模式

    深入理解Java設(shè)計模式之外觀模式

    這篇文章主要介紹了JAVA設(shè)計模式之外觀模式的的相關(guān)資料,文中示例代碼非常詳細,供大家參考和學(xué)習(xí),感興趣的朋友可以了解下
    2021-11-11
  • 深入Java對象的地址的使用分析

    深入Java對象的地址的使用分析

    本篇文章介紹了,Java對象的地址的使用分析。需要的朋友參考下
    2013-05-05
  • SpringBoot項目使用內(nèi)置的單機任務(wù)調(diào)度功能詳解

    SpringBoot項目使用內(nèi)置的單機任務(wù)調(diào)度功能詳解

    這篇文章主要介紹了SpringBoot項目使用內(nèi)置的單機任務(wù)調(diào)度功能詳解,SpringBoot框架中提供了2個注解來讓開發(fā)者快速配置來實現(xiàn)單機定時任務(wù)調(diào)度的功能,分別是@EnableScheduling和 @Scheduled,需要的朋友可以參考下
    2024-01-01
  • Jersey Restful接口如何獲取參數(shù)的問題

    Jersey Restful接口如何獲取參數(shù)的問題

    這篇文章主要介紹了Jersey Restful接口如何獲取參數(shù)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • idea實現(xiàn)類快捷生成接口方法示例

    idea實現(xiàn)類快捷生成接口方法示例

    這篇文章主要介紹了idea實現(xiàn)類快捷生成接口方法示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Java源碼角度分析HashMap用法

    Java源碼角度分析HashMap用法

    這篇文章主要介紹了Java源碼角度分析HashMap用法,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Java常用線程池原理及使用方法解析

    Java常用線程池原理及使用方法解析

    這篇文章主要介紹了Java常用線程池原理及使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07

最新評論