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

}

这样就能解决长度过长的问题。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐