出错背景
代码编写必须要规范,否则后患无穷,排坑的时候,会让你身心皆疲。整合feign和dubbo双支持的时候,本地调试经常用dubbo,没有发现feign这个问题,突然用feign后,发现了调用异常。报错信息为:
2020-07-20 10:19:58.560 ERROR 30920 --- [x-mate-system-2] v.m.c.feign.fallback.MateFeignFallback : MateFeignFallback:[vip.mate.system.feign.ISysRolePermissionProvider.getMenuIdByRoleId] serviceId:[mate-system] message:[[500 Internal Server Error] during [GET] to [http://mate-system/provider/sys-role-permission/get-permission] [ISysRolePermissionProvider#getMenuIdByRoleId(String)]: [{"code":500,"msg":"Request method 'POST' not supported","time":1595211598545}]]
错误原因
/**
* 通过roleId获取权限列表
* @param roleId 角色ID
* @return List
*/
@GetMapping("/provider/sys-role-permission/get-permission")
List<String> getMenuIdByRoleId(String roleId);
手滑,这段代码请求参数未加@RequestParam 或@RequestBody
其他的方法当时都已经加过了,惟独这个方法漏掉了。
解决办法
/**
* 通过roleId获取权限列表
* @param roleId 角色ID
* @return List
*/
@GetMapping("/provider/sys-role-permission/get-permission")
List<String> getMenuIdByRoleId(@RequestParam("roleId") String roleId);
结语
贴上这段代码的目的,就是为了看到这段文字的朋友,JAVA开发必须要规范,容不得半点马虎,否则无数的坑和雷将陪你左右。
贴上源码地址:
版权声明:本文为bufegar0原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。