4、SpringMVC之获取请求参数

打印 上一主题 下一主题

主题 926|帖子 926|积分 2778

4.1 环境搭建

创建名为spring_mvc_demo2的新module,过程参考3.1节
4.1.1、创建请求控制器

  1. package org.rain.controller;
  2. import org.springframework.stereotype.Controller;
  3. /**
  4. * @author liaojy
  5. * @date 2023/10/9 - 8:32
  6. */
  7. @Controller
  8. public class TestParamController {
  9. }
复制代码
  1. package org.rain.controller;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.web.bind.annotation.RequestMapping;
  4. /**
  5. * @author liaojy
  6. * @date 2023/10/9 - 8:49
  7. */
  8. @Controller
  9. public class PortalController {
  10.     @RequestMapping("/")
  11.     public String portal(){
  12.         return "index";
  13.     }
  14. }
复制代码
4.1.2、创建静态资源目录及页面

  1. <!DOCTYPE html>
  2. <html lang="en" xmlns:th="http://www.thymeleaf.org">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>首页</title>
  6. </head>
  7. <body>
  8. </body>
  9. </html>
复制代码
  1. <!DOCTYPE html>
  2. <html lang="en" xmlns:th="http://www.thymeleaf.org">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>成功</title>
  6. </head>
  7. <body>
  8. <h1>success.html</h1>
  9. </body>
  10. </html>
复制代码
4.1.3、配置tomcat



4.2、通过ServletAPI获取请求参数

4.2.1、控制器方法示例


如果控制器方法有HttpServletRequest类型的形参,DispatcherServlet就会将封装了当前请求的对象传给控制器方法
  1.     @RequestMapping("/param/servletAPI")
  2.     public String getParamByServletAPI(HttpServletRequest request){
  3.         String username = request.getParameter("username");
  4.         String password = request.getParameter("password");
  5.         System.out.println("username:"+username);
  6.         System.out.println("password:"+password);
  7.         return "success";
  8.     }
复制代码
4.2.2、页面请求示例

  1. <form th:action="@{/param/servletAPI}" method="post">
  2.     用户名:<input type="text" name="username">
  3.     密码:<input type="password" name="password">
  4.     <input type="submit" value="登录">
  5. </form>
复制代码
4.2.3、测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.3、通过控制器方法的形参获取请求参数

4.3.1、控制器方法示例


如果在控制器方法存在和请求参数同名的形参,DispatcherServlet就会将请求参数赋值给控制器方法中对应的形参
  1.     @RequestMapping("/param")
  2.     public String getParam(String username,String password){
  3.         System.out.println("username:"+username);
  4.         System.out.println("password:"+password);
  5.         return "success";
  6.     }
复制代码
4.3.2、页面请求示例

  1. <form th:action="@{/param/servletAPI}" method="post">
  2.     用户名:<input type="text" name="username">
  3.     密码:<input type="password" name="password">
  4.     <input type="submit" value="登录">
  5. </form>
复制代码
4.3.3、测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.4、@RequestParam注解

@RequestParam注解用于将请求参数和控制器方法的形参建立映射关系,其有三个属性:


  • value:指定要为形参赋值的请求参数的参数名。
  • required:设置是否必须传输此请求参数,默认值为true;
    若设置为true时,则当前请求必须传输value所指定的请求参数,
    若没有传输该请求参数,且没有设置defaultValue属性,则页面报错400:Required String parameter 'xxx' is not present;
    若设置为false时,则当前请求不是必须传输value所指定的请求参数,
    若没有传输该请求参数,则注解所标识的形参的值为null。
  • defaultValue:设置形参的默认值;
    不管required属性值为true或false,当value所指定的请求参数没有传输或传输的值为""时,则使用默认值为形参赋值。
4.4.1、控制器方法示例

  1.     @RequestMapping("/param")
  2.     public String getParam(@RequestParam(value = "name",required = true,defaultValue = "everyone") String username, String password){
  3.         System.out.println("username:"+username);
  4.         System.out.println("password:"+password);
  5.         return "success";
  6.     }
复制代码
4.4.2、页面请求示例

  1. <form th:action="@{/param/servletAPI}" method="post">
  2.     用户名:<input type="text" name="username">
  3.     密码:<input type="password" name="password">
  4.     <input type="submit" value="登录">
  5. </form>
复制代码
4.4.3、有传参的测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.4.4、无传参的测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.5、@RequestHeader和@CookieValue


  • @RequestHeader 注解用于将请求头信息和控制器方法的形参建立映射关系,其三个属性的用法和@RequestParam的相同
  • @CookieValue 注解用于将Cookie数据和控制器方法的形参建立映射关系,其三个属性的用法和@RequestParam的相同
4.5.1、控制器方法示例

  1.     @RequestMapping("/param")
  2.     public String getParam(
  3.             @RequestParam(value = "name",required = true,defaultValue = "everyone") String username,
  4.             String password,
  5.             @RequestHeader("referer") String referer,
  6.             @CookieValue(value = "JSESSIONID",required = false) String jsessionId
  7.     ) {
  8.         System.out.println("username:"+username);
  9.         System.out.println("password:"+password);
  10.         System.out.println("referer:"+referer);
  11.         System.out.println("jsessionId:"+jsessionId);
  12.         return "success";
  13.     }
复制代码
4.5.2、测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.6、通过实体类形参获取请求参数(常用)

4.6.1、实体类示例


注意:要保证实体类的属性名和请求参数名一致
  1. package org.rain.pojo;
  2. /**
  3. * @author liaojy
  4. * @date 2023/10/10 - 8:45
  5. */
  6. public class User {
  7.    
  8.     private Integer id;
  9.     private String username;
  10.     private String password;
  11.     public User() {
  12.     }
  13.     public User(Integer id, String username, String password) {
  14.         this.id = id;
  15.         this.username = username;
  16.         this.password = password;
  17.     }
  18.     public Integer getId() {
  19.         return id;
  20.     }
  21.     public void setId(Integer id) {
  22.         this.id = id;
  23.     }
  24.     public String getUsername() {
  25.         return username;
  26.     }
  27.     public void setUsername(String username) {
  28.         this.username = username;
  29.     }
  30.     public String getPassword() {
  31.         return password;
  32.     }
  33.     public void setPassword(String password) {
  34.         this.password = password;
  35.     }
  36.     @Override
  37.     public String toString() {
  38.         return "User{" +
  39.                 "id=" + id +
  40.                 ", username='" + username + '\'' +
  41.                 ", password='" + password + '\'' +
  42.                 '}';
  43.     }
  44. }
复制代码
4.6.2、控制器方法示例

  1.     @RequestMapping("/param/pojo")
  2.     public String getParamByPojo(User user){
  3.         System.out.println(user);
  4.         return "success";
  5.     }
复制代码
4.6.3、页面请求示例

  1. <form th:action="@{/param/servletAPI}" method="post">
  2.     用户名:<input type="text" name="username">
  3.     密码:<input type="password" name="password">
  4.     <input type="submit" value="登录">
  5. </form>
复制代码
4.6.4、测试效果


+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

+++++++++++++++++++++++++分割线+++++++++++++++++++++++++

4.7、解决获取请求参数的乱码问题

4.7.1、post请求的乱码解决方式


注意:SpringMVC中处理编码的过滤器一定要配置到其他过滤器之前,否则无效;过滤器的顺序根据filter-mapping标签的排序决定。
  1.    
  2.     <filter>
  3.         <filter-name>CharacterEncodingFilter</filter-name>
  4.         <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  5.         <init-param>
  6.             
  7.             <param-name>encoding</param-name>
  8.             <param-value>UTF-8</param-value>
  9.         </init-param>
  10.         <init-param>
  11.             
  12.             <param-name>forceEncoding</param-name>
  13.             <param-value>true</param-value>
  14.         </init-param>
  15.     </filter>
  16.     <filter-mapping>
  17.         <filter-name>CharacterEncodingFilter</filter-name>
  18.         <url-pattern>/*</url-pattern>
  19.     </filter-mapping>
复制代码
4.7.2、get请求的乱码解决方式

从tomcat8及以后的版本,get请求的乱码问题默认已被官方解决;本例展示tomcat7的解决方式。


  • 找到并打开编辑该文件:tomcat安装目录\conf\server.xml
  • 在第一个 Connector 标签中,添加对应的 UTF 编码
  1. URIEncoding="UTF-8"
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

商道如狼道

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表