HTTP 请求 400错误

问题

HTTP 请求 400错误

详细问题

客户端发送请求

java 复制代码
public static UserInfo updateUserInfo(UserInfo userInfo) {
    // 创建 OkHttpClient 对象
    OkHttpClient client = new OkHttpClient();
    // 创建请求体
    MediaType JSON = MediaType.parse("application/json; charset=utf-8");
    RequestBody requestBody = RequestBody.create(JSON,
        "{\"id\": " + userInfo.getId() +
        ", \"avatarBase64\"" + userInfo.getAvatarBase64() + "\"" +
        ", \"nickname\": \"" + userInfo.getNickname() + "\"" +
        ", \"bio\": \"" + userInfo.getBio() + "\"" +
        ", \"birthday\": \"" + userInfo.getBirthday() + "\"}");
    // 创建请求对象
    Request request = new Request.Builder()
        .url("http://192.168.43.127:9090/user_info/update_user_info_by_id")
        .post(requestBody)
        .build();

    // 发送请求并处理响应
    client.newCall(request).enqueue(new Callback() {@
        Override
        public void onResponse(Call call, Response response) throws IOException {
            // 处理响应,这里根据具体情况处理更新成功或失败的逻辑
            String responseData = response.body().string();
            // 在这里处理服务器返回的数据
            System.out.println("responseData" + responseData);

        }

        @
        Override
        public void onFailure(Call call, IOException e) {
            // 处理请求失败的情况
            e.printStackTrace();
        }
    });
    return userInfo;
}

服务端接收请求

java 复制代码
@PostMapping("/update_user_info_by_id")
public int updateUserInfo(@RequestBody UserInfo userInfo) {
    return userInfoService.updateUserInfo(userInfo);
}

客户端控制台打印

java 复制代码
2024-02-17 13:45:21.584 27938-28019/com.example.assistingagriculture I/System.out: responseData{"timestamp":"2024-02-17T05:45:22.846+00:00","status":400,"error":"Bad Request","path":"/user_info/update_user_info_by_id"}

服务端控制台打印

java 复制代码
2024-02-17 13:45:22.841  WARN 26516 --- [nio-9090-exec-6] .w.s.m.s.DefaultHandlerExceptionResolver : Resolved [org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Unexpected character ('1' (code 49)): was expecting a colon to separate field name and value; nested exception is com.fasterxml.jackson.core.JsonParseException: Unexpected character ('1' (code 49)): was expecting a colon to separate field name and value<EOL> at [Source: (PushbackInputStream); line: 1, column: 27]]

解决方案

\"avatarBase64\""修改为\"avatarBase64\": \""

即修改请求体:

java 复制代码
RequestBody requestBody = RequestBody.create(JSON,
    "{\"id\": " + userInfo.getId() +
    ", \"avatarBase64\"" + userInfo.getAvatarBase64() + "\"" +
    ", \"nickname\": \"" + userInfo.getNickname() + "\"" +
    ", \"bio\": \"" + userInfo.getBio() + "\"" +
    ", \"birthday\": \"" + userInfo.getBirthday() + "\"}");

java 复制代码
RequestBody requestBody = RequestBody.create(JSON,
    "{\"id\": " + userInfo.getId() +
    ", \"avatarBase64\": \"" + userInfo.getAvatarBase64() + "\"" +
    ", \"nickname\": \"" + userInfo.getNickname() + "\"" +
    ", \"bio\": \"" + userInfo.getBio() + "\"" +
    ", \"birthday\": \"" + userInfo.getBirthday() + "\"}");

产生原因

产生这个问题的原因是客户端发送的 JSON 请求体格式不正确,导致服务端无法解析请求。具体地说,在客户端构建请求体时,键值对之间缺少了冒号(😃,导致 JSON 解析错误。

解决原因

解决方案中提到的修改请求体的方式即是在键值对之间添加了缺失的冒号,使得 JSON 格式符合标准,从而能够被服务端正确解析。

总结

这种问题通常是由于客户端在构建请求参数时出现了格式错误或者遗漏导致的。在处理类似问题时,需要仔细检查请求体的构建过程,确保 JSON 格式的正确性。

参考文献

产生原因与解释原因部分 部分内容参考chatgpt

原创不易

转载请标明出处

如果对你有所帮助 别忘啦点赞支持哈

相关推荐
不懂机器人16 分钟前
linux网络编程-----TCP服务端并发模型(epoll)
linux·网络·tcp/ip·算法
上海控安1 小时前
上海控安:汽车API安全-风险与防护策略解析
网络·安全·汽车
wuyang-ligerj2 小时前
BGP路由协议(一):基本概念
运维·网络·网络协议·智能路由器
陈天cjq2 小时前
WebSocket 技术详解:协议原理、握手到生产落地的一站式实践
网络·websocket·网络协议
btyzadt3 小时前
Xray与XPOC工具对比分析
网络·安全·web安全
卓码软件测评4 小时前
【第三方网站运行环境测试:服务器配置(如Nginx/Apache)的WEB安全测试重点】
运维·服务器·前端·网络协议·nginx·web安全·apache
蜗牛沐雨4 小时前
HTTP 范围请求:为什么你的下载可以“断点续传”?
网络·网络协议·http
key_Go5 小时前
02.<<设备登录管理:掌握华为网络设备的本地与远程登录技巧>>
运维·服务器·网络·华为
Ciel_75215 小时前
内网穿透工具【frp】的核心功能底层处理逻辑解析
网络·go
superlls6 小时前
(计算机网络)TCP 三握中第三次 ACK 丢失会发生什么?
网络·网络协议·tcp/ip