java 通過發(fā)送json,post請(qǐng)求,返回json數(shù)據(jù)的方法
實(shí)例如下所示:
import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import org.json.JSONArray;
import org.json.JSONObject;
public class GetJsonData {
public static String getJsonData(JSONObject jsonParam,String urls) {
StringBuffer sb=new StringBuffer();
try {
;
// 創(chuàng)建url資源
URL url = new URL(urls);
// 建立http連接
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
// 設(shè)置允許輸出
conn.setDoOutput(true);
// 設(shè)置允許輸入
conn.setDoInput(true);
// 設(shè)置不用緩存
conn.setUseCaches(false);
// 設(shè)置傳遞方式
conn.setRequestMethod("POST");
// 設(shè)置維持長(zhǎng)連接
conn.setRequestProperty("Connection", "Keep-Alive");
// 設(shè)置文件字符集:
conn.setRequestProperty("Charset", "UTF-8");
// 轉(zhuǎn)換為字節(jié)數(shù)組
byte[] data = (jsonParam.toString()).getBytes();
// 設(shè)置文件長(zhǎng)度
conn.setRequestProperty("Content-Length", String.valueOf(data.length));
// 設(shè)置文件類型:
conn.setRequestProperty("contentType", "application/json");
// 開始連接請(qǐng)求
conn.connect();
OutputStream out = new DataOutputStream(conn.getOutputStream()) ;
// 寫入請(qǐng)求的字符串
out.write((jsonParam.toString()).getBytes());
out.flush();
out.close();
System.out.println(conn.getResponseCode());
// 請(qǐng)求返回的狀態(tài)
if (HttpURLConnection.HTTP_OK == conn.getResponseCode(){
System.out.println("連接成功");
// 請(qǐng)求返回的數(shù)據(jù)
InputStream in1 = conn.getInputStream();
try {
String readLine=new String();
BufferedReader responseReader=new BufferedReader(new InputStreamReader(in1,"UTF-8"));
while((readLine=responseReader.readLine())!=null){
sb.append(readLine).append("\n");
}
responseReader.close();
System.out.println(sb.toString());
} catch (Exception e1) {
e1.printStackTrace();
}
} else {
System.out.println("error++");
}
} catch (Exception e) {
}
return sb.toString();
}
public static void main(String[] args) {
JSONObject jsonParam = new JSONObject();
jsonParam.put("id", "1401_1406");
jsonParam.put("device_size", "480x720");
String url="www.baidu.com";
String data=GetJsonData.getJsonData(jsonParam,url);
//返回的是一個(gè)[{}]格式的字符串時(shí):
JSONArray jsonArray = new JSONArray(data);
//返回的是一個(gè){}格式的字符串時(shí):
/*JSONObject obj= new JSONObject(data);*/
}
}
以上這篇java 通過發(fā)送json,post請(qǐng)求,返回json數(shù)據(jù)的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java項(xiàng)目在Idea中開發(fā)遇到所有代碼爆紅的問題與解決辦法
今天打開項(xiàng)目時(shí)發(fā)現(xiàn)idea竟然爆紅,通過查找相關(guān)資料用于解決,下面這篇文章主要給大家介紹了關(guān)于Java項(xiàng)目在Idea中開發(fā)遇到所有代碼爆紅的問題與解決辦法的相關(guān)資料,需要的朋友可以參考下2023-06-06
使用Mock進(jìn)行業(yè)務(wù)邏輯層Service測(cè)試詳解
這篇文章主要介紹了使用Mock進(jìn)行業(yè)務(wù)邏輯層Service測(cè)試詳解,mock是一種模擬對(duì)象的技術(shù),用于在測(cè)試過程中替代真實(shí)的對(duì)象,通過mock,我們可以控制被模擬對(duì)象的行為和返回值,以便進(jìn)行更加精確的測(cè)試,需要的朋友可以參考下2023-08-08
使用@Value 注入 List 類型的配置屬性需要注意的 BUG
這篇文章主要介紹了使用@Value 注入 List 類型的配置屬性需要注意的 BUG,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08
mybatis批量update時(shí)報(bào)錯(cuò)multi-statement not allow的問題
這篇文章主要介紹了mybatis批量update時(shí)報(bào)錯(cuò)multi-statement not allow的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
SpringBoot單元測(cè)試使用@Test沒有run方法的解決方案
這篇文章主要介紹了SpringBoot單元測(cè)試使用@Test沒有run方法的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01
如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解
這篇文章主要介紹了如何使用Java?8中DateTimeFormatter類型轉(zhuǎn)換日期格式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Springboot+redis+Vue實(shí)現(xiàn)秒殺的項(xiàng)目實(shí)踐
本文主要介紹了Springboot+redis+Vue實(shí)現(xiàn)秒殺的項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
使用mybatis的@Interceptor實(shí)現(xiàn)攔截sql的方法詳解
攔截器是一種基于 AOP(面向切面編程)的技術(shù),它可以在目標(biāo)對(duì)象的方法執(zhí)行前后插入自定義的邏輯,本文給大家介紹了使用mybatis的@Interceptor實(shí)現(xiàn)攔截sql的方法,需要的朋友可以參考下2024-03-03

