对于SpringCloud Feign 的 @RequestParam 长度过长问题
在Springcloud项目运行中,难免会各种内部调用接口,参数格式有@RequestParam、@RequestBody 等方式。使用@RequestParam发送请求时会出现异常ERROR IOException: Error writing to server 等异常,这里就要说明下@RequestParam的实现方式了:(1)使用@RequestParam注解将请求参数绑定至方法参数即你可
在Springcloud项目运行中,难免会各种内部调用接口,参数格式有@RequestParam、@RequestBody 等方式。
使用@RequestParam发送请求时会出现异常ERROR IOException: Error writing to server 等异常,这里就要说明下@RequestParam的实现方式了:
(1)使用 @RequestParam 注解将请求参数绑定至方法参数
即你可以使用 @RequestParam 注解将请求参数绑定到你控制器的方法参数上
(2)@RequestParam 有三个属性:
1)value:请求参数名(必须配置)
2)required:是否必需,默认为 true,即 请求中必须包含该参数,如果
没有包含,将会抛出异常(可选配置)
3)defaultValue:默认值,如果设置了该值,required 将自动设为 false,
无论你是否配置了 required,配置了什么值,都是 false(可选配置)
@RequestParam会经过Query String的方式,即便设置了提交方式是post也会将参数拼接在url的后面,然而url传参是有长度限制的(类似于Get请求),会截断后面的参数,致使请求失败 。提供解决方式:
(1)使用org.springframework.util.MultiValueMap对象传参, 将参数放在http请求的body中,就不会出现url长度过长问题 MultiValueMap<String, Object> param =newLinkedMultiValueMap<String, Object>(); param.add("param1", "11"); param.add("param2", "22");
(2)把@RequestParam 的参数全部封装成一个对象,用@RequestBody 方式对该对象进行请求,比如:
// 未修改前
@PostMapping("/send")
ResponseInfo sendWork(@RequestParam("topic") String topic, @RequestParam("message") String message,@RequestParam("key") String key );
// 修改后
@PostMapping("/send")
ResponseInfo sendWorkPush(@RequestBody SendRequest request);
@Data
class SendRequest {
/**
* topic
*/
private String topic;
/**
* message 消息值
*/
private String message;
/**
* key 唯一值
*/
private String key;
}
这样就能解决长度过长的问题。
更多推荐
所有评论(0)