zoukankan      html  css  js  c++  java
  • SpringMV常用注解之@requestbody和@requestparam

    基本介绍

    • @requestparam

    属性介绍

    1. required:表示是否必须,默认为 true,必须
    2. defaultValue:可设置请求参数的默认值
    3. value:为接收url的参数名(相当于key值)
    • @requestbody

    属性介绍

    1. required:表示是否必须,默认为 true,必须

    使用方式

    @requestparam

       @RequestParam用来处理 Content-Type:application/x-www-form-urlencoded编码的内容,Content-Type默认为该属性。@RequestParam也可用于其它类型的请求,例如:POST、DELETE等请求。但是这样不支持批量插入数据,如果改用json字符串来传值的话,类型设置为 application/json,点击发送的话,会报错,后台接收不到值,为null。这时候,注解@RequestBody就派上用场了。

    注意:方法中参数类型为实体时不能够使用@RequestParam,否则会报400的错误。当然如果把@RequestParam(required = false)加到试题类型参数前面,就不会报错,但是实体类也不会被赋值。

        @GetMapping("test1")
        @ResponseBody
        public String test1(String userName, Integer age) {
            return "姓名:" + userName + ",年龄:" + age;
        }
    
        @GetMapping("test2")
        @ResponseBody
        public String test2(UserEntity userEntity, String userName, Integer age) {
            return "用户:" + JSONUtil.toJsonStr(userEntity) + "姓名:" + userName + ",年龄:" + age;
        }
    
        @GetMapping("test3")
        @ResponseBody
        public String test3(UserEntity userEntity, @RequestParam(name = "name", required = false) String userName,Integer age) {
            return "用户:" + JSONUtil.toJsonStr(userEntity) + "姓名:" + userName + ",年龄:" + age;
        }

    @requestbody

      注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/json、application/xml等类型的数据。就application/json类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析

      GET请求中,因为没有HttpEntity,所以@RequestBody并不适用。

      POST请求中,通过HttpEntity传递的参数,必须要在请求头中声明数据的类型Content-Type,SpringMVC通过使用HandlerAdapter 配置的HttpMessageConverters来解析HttpEntity中的数据,然后绑定到相应的bean上。

    注意:前端使用$.ajax的话,一定要指定 contentType: "application/json;charset=utf-8;",默认为 application/x-www-form-urlencoded

         @PostMapping("test4")
        @ResponseBody
        public String test4(@RequestBody List<UserEntity> lists) {
            return "用户:" + JSONUtil.toJsonStr(lists);
        }
    
        @PostMapping("test5")
        @ResponseBody
        public String test5(@RequestBody List<Map<String, Object>> maps) {
            return "用户:" + JSONUtil.toJsonStr(maps);
        }

    通过postman正确调用:

     如果使用form表单提交,就会报错:

      @RequestBody和@RequestParam的请求方式get和post关系

  • 相关阅读:
    关于软工文档规范性——国标文档
    关于游戏平衡性——王者荣耀野怪数值参考
    单元测试特性标签(结合代码)
    常用标签梳理
    图片文件的转换、加载及缩放显示
    认识ManualResetEvent
    HTML简介
    HTML基本结构
    15年,我在深圳
    为什么坚持,想一想当初
  • 原文地址:https://www.cnblogs.com/htyj/p/13365476.html
Copyright © 2011-2022 走看看