SpringMVC--请求参数绑定及常用注解

请求参数的绑定

  1. 请求参数的绑定说明

    1. 绑定机制
      1. 表单提交的数据都是k=v格式的 username=haha&password=123
      2. SpringMVC的参数绑定过程是把表单提交的请求参数,作为控制器中方法的参数进行绑定的
      3. 要求:提交表单的name和参数的名称是相同的
    2. 支持的数据类型
    3. 基本数据类型和字符串类型
    4. 实体类型(JavaBean)
    5. 集合数据类型(List、map集合等)
  2. 基本数据类型和字符串类型

    1. 提交表单的name和参数的名称是相同的
    2. 区分大小写
  3. 实体类型(JavaBean)

    1. 提交表单的name和JavaBean中的属性名称需要一致
    2. 如果一个JavaBean类中包含其他的引用类型,那么表单的name属性需要编写成:对象.属性 例如:
      address.name
  4. 给集合属性数据封装1. JSP页面编写方式:list[0].属性

  5. 请求参数中文乱码的解决

    1. 在web.xml中配置Spring提供的过滤器类
        <!-- 配置过滤器,解决中文乱码的问题 -->
        <filter>
            <filter-name>characterEncodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filterclass>
            <!-- 指定字符集 -->
            <init-param>
                <param-name>encoding</param-name>
                <param-value>UTF-8</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>characterEncodingFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>
    
    
  6. 自定义类型转换器

    1. 表单提交的任何数据类型全部都是字符串类型,但是后台定义Integer类型,数据也可以封装上,说明
      Spring框架内部会默认进行数据类型转换。

    2. 如果想自定义数据类型转换,可以实现Converter的接口

      1. 自定义类型转换器
      2. 注册自定义类型转换器,在springmvc.xml配置文件中编写配置
          <!-- 注册自定义类型转换器 -->
          <bean id="conversionService"
          class="org.springframework.context.support.ConversionServiceFactoryBean">
              <property name="converters">
              <set>
                  <bean class="cn.itcast.utils.StringToDateConverter"/>
              </set>
          </property>
          </bean>
          
          <!-- 开启Spring对MVC注解的支持 -->
          <mvc:annotation-driven conversion-service="conversionService"/>
      
  7. 在控制器中使用原生的ServletAPI对象

    1. 只需要在控制器的方法参数定义HttpServletRequest和HttpServletResponse对象

常用的注解

  1. RequestParam注解

    1. 作用:把请求中的指定名称的参数传递给控制器中的形参赋值
    2. 属性
      1. value:请求参数中的名称

      2. required:请求参数中是否必须提供此参数,默认值是true,必须提供

        @RequestMapping(path="/hello")
        public String sayHello(@RequestParam(value="username",required=false)String name) {
            System.out.println("aaaa");
            System.out.println(name);
            return "success";
        }
        
  2. RequestBody注解

    1. 作用:用于获取请求体的内容(注意:get方法不可以)
    2. 属性
      1. required:是否必须有请求体,默认值是true
    @RequestMapping(path="/hello")
    public String sayHello(@RequestBody String body) {
        System.out.println("aaaa");
        System.out.println(body);
        return "success";
    }
    
  3. PathVariable注解

    1. 作用:拥有绑定url中的占位符的。例如:url中有/delete/{id},{id}就是占位符
    2. 属性
      1. value:指定url中的占位符名称
    3. Restful风格的URL
      1. 请求路径一样,可以根据不同的请求方式去执行后台的不同方法
      2. restful风格的URL优点
        1. 结构清晰
        2. 符合标准
        3. 易于理解
        4. 扩展方便
    @RequestMapping(path="/hello/{id}")
    public String sayHello(@PathVariable(value="id") String id) {
        System.out.println(id);
        return "success";
    }
    
  4. RequestHeader注解

    1. 作用:获取指定请求头的值
    2. 属性
      1. value:请求头的名称
    @RequestMapping(path="/hello")
    public String sayHello(@RequestHeader(value="Accept") String header) {
        System.out.println(header);
        return "success";
    }
    
  5. CookieValue注解

    1. 作用:用于获取指定cookie的名称的值
    2. 属性
      1. value:cookie的名称
    @RequestMapping(path="/hello")
    public String sayHello(@CookieValue(value="JSESSIONID") String cookieValue) {
        System.out.println(cookieValue);
        return "success";
    }
    
  6. ModelAttribute注解

    1. 作用
      1. 出现在方法上:表示当前方法会在控制器方法执行前线执行。
      2. 出现在参数上:获取指定的数据给参数赋值。
    2. 应用场景
      1. 当提交表单数据不是完整的实体数据时,保证没有提交的字段使用数据库原来的数据。

    修饰的方法有返回值

    /**
    * 作用在方法,先执行
    * @param name
    * @return
    */
    @ModelAttribute
    public User showUser(String name) {
        System.out.println("showUser执行了...");
        // 模拟从数据库中查询对象
        User user = new User();
        user.setName("哈哈");
        user.setPassword("123");
        user.setMoney(100d);
        return user;
    } /
    **
    * 修改用户的方法
    * @param cookieValue
    * @return
    */
    @RequestMapping(path="/updateUser")
    public String updateUser(User user) {
        System.out.println(user);
        return "success";
    }
    

    修饰的方法没有返回值

    /
    **
    * 作用在方法,先执行
    * @param name
    * @return
    */
    @ModelAttribute
    public void showUser(String name,Map<String, User> map) {
        System.out.println("showUser执行了...");
        // 模拟从数据库中查询对象
        User user = new User();
        user.setName("哈哈");
        user.setPassword("123");
        user.setMoney(100d);
        map.put("abc", user);
    } 
    
    /**
    * 修改用户的方法
    * @param cookieValue
    * @return
    */
    @RequestMapping(path="/updateUser")
    public String updateUser(@ModelAttribute(value="abc") User user) {
        System.out.println(user);
        return "success";
    }
    
  7. SessionAttributes注解

    1. 作用:用于多次执行控制器方法间的参数共享
    2. 属性
      1. value:指定存入属性的名称
    @Controller
    @RequestMapping(path="/user")
    @SessionAttributes(value= {"username","password","age"},types=
    {String.class,Integer.class}) // 把数据存入到session域对象中
    public class HelloController {
        /**
        * 向session中存入值
        * @return
        */
        @RequestMapping(path="/save")
        public String save(Model model) {
            System.out.println("向session域中保存数据");
            model.addAttribute("username", "root");
            model.addAttribute("password", "123");
            model.addAttribute("age", 20);
            return "success";
        }
        
        /**
        * 从session中获取值
        * @return
        */
        @RequestMapping(path="/find")
        public String find(ModelMap modelMap) {
            String username = (String) modelMap.get("username");
            String password = (String) modelMap.get("password");
            Integer age = (Integer) modelMap.get("age");
            System.out.println(username + " : "+password +" : "+age);
            return "success";
        } 
        
        /**
        * 清除值
        * @return
        */
        @RequestMapping(path="/delete")
        public String delete(SessionStatus status) {
            status.setComplete();
            return "success";
        }
    }
    
发布了56 篇原创文章 · 获赞 8 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/Dawn510/article/details/104421066