当前位置 博文首页 > 闫玉林的博客:spring cloud微服务接口调用,参数传递失败Requir

    闫玉林的博客:spring cloud微服务接口调用,参数传递失败Requir

    作者:[db:作者] 时间:2021-08-17 18:53

    现象

    • 有一个spring boot 服务,对外提供查询的接口

    • 另外3个服务分别去调用这个接口

    • 2个tomcat的服务,调用成功

    • 1个jar启动的spring boot服务,调用失败,参数传递不过去

    • 关键报错日志 Required Long parameter 'userId' is not present,日志截图如下:
      在这里插入图片描述

    • 接口是通的,但是参数值传递失败,对方只接收到null值,导致报错提示

    • FeignClient里面的接口

    @RequestMapping(value = "/api/auth/loader/user/loadSystemMenu", method = RequestMethod.POST, consumes = MediaType.APPLICATION_JSON_VALUE)
    List<AuthMenuVO> loadSystemMenu(@RequestParam(name = "userId") Long userId, @RequestParam(name = "sysCode") String sysCode);
    
    • 实现类
    @RequestMapping(value = "loadSystemMenu")
    public List<AuthMenuVO> loadSystemMenu(@RequestParam(name = "userId") Long userId, @RequestParam(name = "sysCode") String sysCode) {
        List<AuthMenuVO> menuVOList = authMenuService.getUserMenuBySysCode(userId, sysCode);
        return menuVOList;
    }
    

    剖析

    • 该接口功能没问题,因为另外2个tomcat服务调用都成功了,参数传递也没问题。失败的是内置tomcat使用jar启动的spring boot工程,应该是和spring注解或相关默认配置有关
    • 该接口注明是POST方式,但是调用方使用的是默认的get方式
    • 实现类上有@RequestParam注解,这个是get方式需要用到的

    解决

    • 第一次尝试,将Long改为long,由包装类型改为基本类型,无用
    • 第二次尝试,将实现类的@RequestParam注解去除,不报错了,但是值传不过去
    • 第三次尝试,将接口里的调用方式post改为get,成功

    总结

    • 参数传递失败时,需要将post请求,改为get请求
    • 具体原因还在探究中,怀疑是spring boot里的哪些默认配置,限制了POST方式使用@RequestParam,后续有时间再深入源码继续测试
    cs
    下一篇:没有了