HTTP 请求 400错误

问题

HTTP 请求 400错误

详细问题

客户端发送请求

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;
}

服务端接收请求

@PostMapping("/update_user_info_by_id")
public int updateUserInfo(@RequestBody UserInfo userInfo) {
    return userInfoService.updateUserInfo(userInfo);
}

客户端控制台打印

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"}

服务端控制台打印

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\": \""
即修改请求体:

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

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

原创不易
转载请标明出处
如果对你有所帮助 别忘啦点赞支持哈
请添加图片描述

你可能感兴趣的:(http,网络协议,网络)