首页 > 其他分享 >OkHTTP发送POST请求传送JSON数据

OkHTTP发送POST请求传送JSON数据

时间:2024-01-23 14:22:49浏览次数:27  
标签:map JSONObject private put JSON static OkHTTP import POST

导入依赖

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.squareup.okhttp3</groupId>
            <artifactId>okhttp</artifactId>
            <version>3.14.9</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.75</version>
        </dependency>
    </dependencies>

编写一个接口

    @RequestMapping("/Json")
    @ResponseBody
    public JSONObject Json(@RequestBody JSONObject map) {
        System.out.println(map);
        map.put("success", true);
        map.put("msg", UUID.randomUUID().toString());
        HashMap<String, Object> stringObjectHashMap = new HashMap<>();
        stringObjectHashMap.put("token", "asdascfr22rwf");
        map.put("response", stringObjectHashMap);
        return map;
    }

编写OkHTTP的测试类发送请求这个接口

package com.example.demo.demos.web;

import com.alibaba.fastjson.JSONObject;
import okhttp3.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.util.UUID;
import java.util.concurrent.TimeUnit;

public class HttpClentTest {

    private final static String httpHeaderMediaType = "application/json;charset=utf-8";

    private final static String httpHeaderContentType = "Content-Type";

    private final static Logger logger = LoggerFactory.getLogger(HttpClentTest.class);

    /**
     * 设置默认30秒Http调用超时
     */
    private final static OkHttpClient client = new OkHttpClient.Builder()
            .connectTimeout(30, TimeUnit.SECONDS)
            .readTimeout(30, TimeUnit.SECONDS)
            .callTimeout(30, TimeUnit.SECONDS)
            .build();
    public static void main(String[] args) {
        JSONObject jsonBody = new JSONObject();
        jsonBody.put("appKey", UUID.randomUUID().toString());
        jsonBody.put("appSecret", UUID.randomUUID().toString());
        //  构建Request对象
        RequestBody requestBody = RequestBody.create(MediaType.parse(httpHeaderMediaType), jsonBody.toJSONString());
        Request request = new Request.Builder()
                .addHeader(httpHeaderContentType, httpHeaderMediaType)
                .addHeader("Accept", httpHeaderMediaType)
                .post(requestBody)
                .url("http://localhost:8282/Json")
                .build();
        Response signRsp = null;
        try {
            signRsp = client.newCall(request).execute();
            if (signRsp.isSuccessful()) {
                String body = signRsp.body().string();
                JSONObject respBody = JSONObject.parseObject(body);
                if (respBody.getBoolean("success")) {
                    System.out.println("===================================Token===================================");
                    System.out.println(respBody.getJSONObject("response").getString("token"));
                } else {
                    logger.error("Http连接OpenapiAPi地址:openapiLoginUrl  失败,MSG= {}", respBody.getString("msg"));
                }
            }
        } catch (IOException e) {
            logger.error("Http连接OpenapiAPi地址:openapiLoginUrl  失败", e);
        }
    }
}

成功测试结果

===================================Token===================================
asdascfr22rwf

标签:map,JSONObject,private,put,JSON,static,OkHTTP,import,POST
From: https://www.cnblogs.com/gtnotgod/p/17982351

相关文章

  • PostMappering中consumes与produces属性的作用
     哈喽大家好今天跟大家简单聊一聊PostMappering中consumers与produces两个属性的作用在对接接口中,对方API要求,请求头HTTPHeader中设置Content-Type为application/x-www-form-urlencoded,响应头HTTPHeader中Content-Type为application/json。也就是说一个接口中,接收......
  • OPENJSON requires Compatibility Level 130
    ParseandTransformJSONDatawithOPENJSONOPENJSONrequiresCompatibilityLevel130TheOPENJSONfunctionisavailableonlyundercompatibilitylevel130.Ifyourdatabasecompatibilitylevelislowerthan130,SQLServercan'tfindandruntheO......
  • js中的bigint类型转化为json字符串时报无法序列化的问题
    网上查了一下,解决这个问题的思路就是将bigint类型的数据转化为字符串,这样就能正确转化为json字符串了。对于一个是bigint的变量,直接使用toString方法就可以转化为字符串了,但是bigint变量在一个对象中,那么我们就需要一个更加通用的方法,网上看到一个很好的封装好的方法,如下。expor......
  • Java开发者的Python进修指南:JSON利器之官方json库、demjson和orjson的实用指南
    JSONJSON作为目前最流行的传输格式,在Python中也有相应的实现方式。由于JSON格式的文本可以跨平台并且简单易用,因此被广泛传播。因此,我们今天的主要讨论内容是如何熟练地应用Python的JSON库来处理将JSON映射到文本,以及如何从文本映射到对象中。现在,让我们开始探讨这个话题。官方j......
  • PostgreSQL安装
    一、下载安装1.1解压https://www.postgresql.org/ftp/source/v10.3/tar‐zxvfpostgresql‐10.3.tar.gz1.2安装依赖#centosyum‐yinstallzlib‐develreadline‐devel#ubuntusudoapt-cachesearchreadlinesudoaptinstalllib64readline8lib64readline-de......
  • 【数据库】对大数据量数据集,PostgreSQL分组统计数量,限定每组最多数量
    一、背景介绍在处理大数据量数据集时,我们经常需要进行分组统计。例如,我们需要统计每个城市的人口数量、每个年龄段的人数等。在PostgreSQL中,我们可以使用row_number()函数结合over(partitionby)子句来实现这个功能。同时,为了限定每组最多数量,我们可以使用row_num<=100......
  • 【数据库】对大数据量数据集,PostgreSQL分组统计数量,限定每组最多数量
    一、背景介绍在处理大数据量数据集时,我们经常需要进行分组统计。例如,我们需要统计每个城市的人口数量、每个年龄段的人数等。在PostgreSQL中,我们可以使用row_number()函数结合over(partitionby)子句来实现这个功能。同时,为了限定每组最多数量,我们可以使用row_num<=100......
  • 【数据库】对大数据量数据集,PostgreSQL分组统计数量,限定每组最多数量
    一、背景介绍在处理大数据量数据集时,我们经常需要进行分组统计。例如,我们需要统计每个城市的人口数量、每个年龄段的人数等。在PostgreSQL中,我们可以使用row_number()函数结合over(partitionby)子句来实现这个功能。同时,为了限定每组最多数量,我们可以使用row_num<=100......
  • 既是API调试平台也是自动化测试工具?Apipost
    Apipost提供可视化的API自动化测试功能,使用Apipost研发人员可以设计、调试接口,测试人员可以基于同一数据源进行测试,Apipost接口自动化功能在上次更新中进行了逻辑调整,带来更好的交互操作、更多的控制器选择,同时新增同步接口模式选择、测试数据选择功能。添加接口使用Apipost,研发......
  • 想在IDEA中调试API?试试这款,堪比postman
    Postman是大家最常用的API调试工具,那么有没有一种方法可以不用手动写入接口到Postman,即可进行接口调试操作?今天给大家推荐一款IDEA插件:ApipostHelper,写完代码就可以调试接口并一键生成接口文档!而且还可以根据已有的方法帮助您快速生成url和params。更重要的是他完全免费!Apipost......