当前位置:首页 > JAVA > 正文内容

springboot请求接口400错误的排查

高老师1年前 (2024-02-20)JAVA479

今天在新增1个接口的时候请求接口一直400,无任何错误信息,接口代码如下:

@SaveLog(name = "同步商品档案")
@ApiOperation(value = "同步商品档案", notes = "同步商品档案")
@PostMapping(value = "/sync", produces = "application/json;charset=UTF-8")
public void sync(@RequestBody StyleBillsRequest req) throws IOException {
    iRetailDataService.sync(req);
}

经过同事的指点可能是请求参数json和实体对象有差异,结构可能不正确,我检查半天无果,于是先通过json接收再转换为实体对象。更换代码如下:

@SaveLog(name = "同步商品档案")
@ApiOperation(value = "同步商品档案", notes = "同步商品档案")
@PostMapping(value = "/sync", produces = "application/json;charset=UTF-8")
public void sync(@RequestBody JSONObject data) throws IOException {
    // 转换Json实体对象
    StyleBillsRequest req = JsonUtil.JsonToBean(JsonUtil.toJSONString(data), StyleBillsRequest.class);

    // 同步商品档案信息
    iRetailDataService.sync(req);
}

这样修改代码后会报错部分字段的值无法转换,很清晰的了解到json结构中哪些字段有问题,方便修改。

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/723.html

分享给朋友:

“springboot请求接口400错误的排查” 的相关文章

Java不用编译直接执行

Java不用编译直接执行

public class test {     public static void main(String[] args) {     &...

java编译编码问题,java编译执行时编码问题

java编译编码问题,java编译执行时编码问题

public class test {     public static void main(String[] args) {     &...

java睡眠方法,java睡眠函数,java睡眠时间,java睡眠一分钟,java睡眠五秒钟

java睡眠方法,java睡眠函数,java睡眠时间,java睡眠一分钟,java睡眠五秒钟

(1).java睡眠函数Thread.sleep(时间);  //单位为毫秒(2).java睡眠函数例子Date dNow = new Date(); SimpleDateFormat ft = new&nbs...

java获取时间戳,java时间戳获取

java获取时间戳,java时间戳获取

System.out.println("当前时间戳(秒): " + System.currentTimeMillis()/1000); System.out.println("当前时间戳(毫秒): " +&nb...

java正则表达式判断字符串是否包含,java判断字符串是否包含

java正则表达式判断字符串是否包含,java判断字符串是否包含

pattern表示正则表达式,接收正则表达式作为参数例子:String content = "my name is gaojiufeng"; String pattern = "....

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end

java匹配一个字符串在另外一个字符串中出现的次数,java正则start,java正则end// 正则 String pattern = "\\bgao\\b"; // 字符串 String content ...