HttpURLConnection发送POST请求传递JSON参数

java 复制代码
public class POSTJson2 {
    public static void main(String[] args) {
        try {

            String defURL = "https://api.apiopen.top/api/login";
            URL url = new URL(defURL);
            HttpURLConnection con = (HttpURLConnection) url.openConnection();
            con.setRequestMethod("POST");//请求POST方式
            con.setRequestProperty("Content-Type","application/json;charset=UTF-8");
            con.setDoOutput(true);// 设置是否使用HttpURLConnection进行输出,默认值为 false
            
            OutputStreamWriter writer = new OutputStreamWriter(con.getOutputStream(), "UTF-8");
            String body = "{\"account\":\"309324904@qq.com\",\"password\":\"123456\"}";
            writer.write(body);
            writer.flush();
            writer.close();

            int code = con.getResponseCode();
            System.out.println("http状态码:" + code);
            if (code == HttpURLConnection.HTTP_OK) {
                System.out.println("测试成功");
            } else {
                System.out.println("测试失败:" + code);
            }

            // 获取服务端响应,通过输入流来读取URL的响应
            InputStream is = con.getInputStream();
            BufferedReader reader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
            StringBuffer sbf = new StringBuffer();
            String strRead = null;
            while ((strRead = reader.readLine()) != null) {
                sbf.append(strRead);
                sbf.append("\r\n");
            }
            reader.close();

            // 关闭连接
            con.disconnect();

            // 打印读到的响应结果
            System.out.println("运行结束:" + sbf.toString());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

运行结果:

复制代码
http状态码:200
测试成功
运行结束:{"code":200,"message":"成功!","result":{"id":572,"createdAt":"2022-12-09 08:28:14","updatedAt":"2022-12-09 08:28:14","deletedAt":null,"account":"309324904@qq.com","level":0,"token":"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aWQiOjU3MiwiaWQiOjU3MiwiY3JlYXRlZEF0IjoiMjAyMi0xMi0wOSAwODoyODoxNCIsInVwZGF0ZWRBdCI6IjIwMjItMTItMDkgMDg6Mjg6MTQiLCJkZWxldGVkQXQiOm51bGwsImFjY291bnQiOiIzMDkzMjQ5MDRAcXEuY29tIiwibGV2ZWwiOjAsImV4cCI6MTcyMDk2MDU2NCwiaXNzIjoiYXBpX29wZW4iLCJuYmYiOjE3MjAzNTQ3NjR9.NaW12ztp0jy3auF3ZACc_OX6vI_ERe87uB6PWC4Ycn8"}}

返回的json数据整理下:

复制代码
{
    "code": 200,
    "message": "成功!",
    "result": {
        "id": 572,
        "createdAt": "2022-12-09 08:28:14",
        "updatedAt": "2022-12-09 08:28:14",
        "deletedAt": null,
        "account": "309324904@qq.com",
        "level": 0,
        "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aWQiOjU3MiwiaWQiOjU3MiwiY3JlYXRlZEF0IjoiMjAyMi0xMi0wOSAwODoyODoxNCIsInVwZGF0ZWRBdCI6IjIwMjItMTItMDkgMDg6Mjg6MTQiLCJkZWxldGVkQXQiOm51bGwsImFjY291bnQiOiIzMDkzMjQ5MDRAcXEuY29tIiwibGV2ZWwiOjAsImV4cCI6MTcyMDk2MDU2NCwiaXNzIjoiYXBpX29wZW4iLCJuYmYiOjE3MjAzNTQ3NjR9.NaW12ztp0jy3auF3ZACc_OX6vI_ERe87uB6PWC4Ycn8"
    }
}

上面是手写的json字符串,如果使用java官方的安装包javax.json,json字符串拼接如下:

java 复制代码
JsonObject object= Json.createObjectBuilder()
        .add("account","309324904@qq.com")
        .add("password","123456")
        .build();
writer.write(object.toString());

完整代码如下:

java 复制代码
import javax.json.Json;
import javax.json.JsonObject;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.URL;

public class POSTJson2 {
    public static void main(String[] args) {
        try {
            String defURL = "https://api.apiopen.top/api/login";
            URL url = new URL(defURL);
            HttpURLConnection con = (HttpURLConnection) url.openConnection();
            con.setRequestMethod("POST");//请求POST方式
            con.setRequestProperty("Content-Type","application/json;charset=UTF-8");
            con.setDoOutput(true);// 设置是否使用HttpURLConnection进行输出,默认值为 false

            OutputStreamWriter writer = new OutputStreamWriter(con.getOutputStream(), "UTF-8");
            JsonObject object= Json.createObjectBuilder()
                    .add("account","309324904@qq.com")
                    .add("password","123456")
                    .build();
            writer.write(object.toString());
            writer.flush();
            writer.close();



            int code = con.getResponseCode();
            System.out.println("http状态码:" + code);
            if (code == HttpURLConnection.HTTP_OK) {
                System.out.println("测试成功");
            } else {
                System.out.println("测试失败:" + code);
            }

            // 获取服务端响应,通过输入流来读取URL的响应
            InputStream is = con.getInputStream();
            BufferedReader reader = new BufferedReader(new InputStreamReader(is, "UTF-8"));
            StringBuffer sbf = new StringBuffer();
            String strRead = null;
            while ((strRead = reader.readLine()) != null) {
                sbf.append(strRead);
                sbf.append("\r\n");
            }
            reader.close();

            // 关闭连接
            con.disconnect();

            // 打印读到的响应结果
            System.out.println("运行结束:" + sbf.toString());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
相关推荐
wtsolutions1 小时前
免费MCP: JSON 转 Excel MCP
json·excel·api·csv·mcp·wtsolutions
杨DaB3 小时前
【项目实践】在系统接入天气api,根据当前天气提醒,做好plan
java·后端·spring·ajax·json·mvc
hqxstudying21 小时前
前后端交流
java·css·后端·html·json
Vic101013 天前
Hutool 的完整 JSON 工具类示例
开发语言·json
电商数据girl3 天前
如何利用API接口与网页爬虫协同进行电商平台商品数据采集?
大数据·开发语言·人工智能·python·django·json
拷斤锟3 天前
使用Excel解析从OData API获取到的JSON数据
数据库·json·excel
有育哥无奔波4 天前
是采用示例模板,还是采用json的结构化数据,哪种方式会让llm的输出更加稳定?
json
小小李程序员4 天前
JSON.parse解析大整数踩坑
开发语言·javascript·json
西哥写代码6 天前
基于dcmtk的dicom工具 第九章 以json文件或sqlite为数据源的worklist服务(附工程源码)
sqlite·json·mfc·dcmtk·worklist
Mu.3876 天前
JSON解析
json