SpringMVC获取请求参数

简介: 上一篇文章我们学习了@RequestMapping注解,明白浏览器与服务器之间是如何映射的,今天我们一起学习如何获取SpringMVC中请求映射中的参数信息。

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

在控制器方法的形参位置设置与请求参数名相同的形参,当浏览器发送请求,并匹配到请求映射时,在DispatcherServlet中就会将请求参数赋值给对应的控制器方法形参。
@Controller
public class TestParam {
    @RequestMapping("/testParam")
    public String testParam(String name, String pwd,String[] hobby){
        System.out.println("name:"+ name +",password:"+ pwd +",hobby:" + Arrays.toString(hobby));
        return "success";
    }
}
  • 通过form表单提交数据:
<form th:action="@{/testParam}" method="get">
    用户名:<input type="text" name="name"><br>
    密码:<input type="password" name="pwd"><br>
    爱好:<input type="checkbox" name="hobby" value="a">a
    <input type="checkbox" name="hobby" value="b">b
    <input type="checkbox" name="hobby" value="c">c<br>
    <input type="submit" value="传参测试">
</form>
  • 传入参数:

在这里插入图片描述

  • 传参成功:在这里插入图片描述

控制台输出:
在这里插入图片描述
注意:若请求参数中出现多个同名的请求参数,可以在控制器方法的形参位置设置字符串类型或字符串数组接受该请求参数;若使用字符串类型的形参,最终结果为请求参数的每一个值之间用逗号拼接的结果。

通过控制器方法的形参来获取请求参数虽然很简单,但是前提条件时请求参数与控制器方法的形参名要一致,如果不一致就会输出一个空值null。那么如何解决这一问题呢?继续看下面

二、 @RequestParam获取请求的参数

默认情况下,可以直接在方法的参数中填写跟请求一样的名称,此时会默认接受参数, 如果有值,直接赋值;如果没有,那么直接给空值。
@RequestParam:获取请求中的参数值,使用此注解之后,控制器方法的形参名称不需要跟请求的名称一致了,但是必须要写
此注解还包含三个参数:

  • value:表示要获取的参数值;
  • required:表示此参数是否必须传值,默认值为true,如果不写参数就会报错,如果将值设为false,那么不写参数也不会报任何错误;
  • defaultValue:不管required的值是什么,只要在使用的时候没有传递参数,那么只需定义默认值即可。
  • 将请求参数的名称与控制器方法的名称设为不一致
<form th:action="@{/testParam}" method="get">
    用户名:<input type="text" name="name"><br>
    密码:<input type="password" name="password"><br>
    <input type="submit" value="传参测试">
</form>
  • 设置@RequestParam注解的属性及属性值
@Controller
public class TestParam {
    @RequestMapping("/testParam")
    public String testParam(
    @RequestParam(value = "name",required = false,defaultValue = "admin")
    String username, String password){
        System.out.println("username:"+ username +",password:"+ password);
        return "success";
    }
}
  • 在这里我们设置了 @RequestParam 注解的所有属性,我们现在只输入密码,然后提交表单

在这里插入图片描述

  • 提交成功了,并且可以在地址栏看到name后面的值为空

在这里插入图片描述

  • 但是由于我们设置了defaultValue,所以在控制台输出结果如下:

在这里插入图片描述
这时候我们再看另一种情况,将注解部分改为@RequestParam(value = "name",required = true) String username, String password

在这里插入图片描述
当required的值为true时,则当前的请求参数不能为空,如果没有传入参数,并且没有设置defaultValue属性,那么就会报错400,如上图所示;当required的值为false,则可以不传参,不传则输出null

三、@RequestHeader获取请求头信息

@RequestHeader注解是创建请求头信息和控制器方法的形参之间的映射关系
同样,此注解中也包含三个参数 value、required、defalutValue,跟@RequestParam的用法一样,就不过多介绍了
@RequestMapping("/header")
    public String header(@RequestHeader(value = "host") String host){
        System.out.println("host:" + host);
        return "success";
    }

此时的请求映射的请求路径为:http://localhost:8080/springmvc_study02/header
能够成功的获取到请求头信息host:localhost:8080

四、@CookieValue获取cookie中的值

@CookieValue注解是创建cookie和控制器方法的形参之间的映射关系,如果要获取cookie中没有的信息,那么此时会报错400,同样,此注解中也包含三个参数,跟@RequestParam一样。
@RequestMapping("/cookie")
    public String cookie(@CookieValue("JSESSIONID") String cookie){
        System.out.println("cookie:" + cookie);
        return "success";
    }

此时的请求映射的请求路径为:http://localhost:8080/springmvc_study02/cookie
能够成功的获取到请求头信息cookie:8EF5E48530CADBD827F5354E8308E423

五、 获取复杂数据类型的请求参数

我们可以在控制器方法的形参位置放一个实体类型的形参,如果传入的参数与实体类的属性一一匹配,那么请求参数就能成功为该形参赋值。
  • 创建实体类,并编写getter/setter方法,有参、无参构造方法以及重写toString方法
public class Student {
    private Integer id;
    private String name;
    private String sex;
    private String phone;
}
  • 创建控制器方法
@RequestMapping("/testPOJO")
    public String testPOJO(Student student){
        System.out.println(student);
        return "success";
    }
  • 通过表单传入参数
<form th:action="@{/testPOJO}" method="post">
    id:<input type="text" name="id"><br>
    姓名:<input type="text" name="name"><br>
    性别:<input type="radio" name="sex" value="男">男
         <input type="radio" name="sex" value="女">女<br>
    手机:<input type="text" name="phone"><br>
    <input type="submit" value="传参测试">
</form>

此时的请求映射的请求路径为:http://localhost:8080/springmvc_study02/testPOJO
能够成功的获取到参数
Student{id=1001, name='admin', sex='男', phone='15211111111'}

七、 如何解决乱码问题

我们在使用表单发送请求的时候,经常会遇到中文乱码的问题,那么如何解决乱码问题呢?
  • GET请求:在tomcat的conf文件夹下的server.xml文件中,添加URIEncoding=“UTF­8”
  • POST请求:编写过滤器进行实现
<filter>
        <filter-name>characterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>characterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

注意:如果配置了多个过滤器,那么字符编码过滤器一定要在最前面,否则就会失效。

相关文章
|
7月前
|
前端开发 Java 测试技术
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
347 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
|
7月前
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
531 0
|
7月前
|
前端开发 Java 微服务
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@PathVariable
`@PathVariable` 是 Spring Boot 中用于从 URL 中提取参数的注解,支持 RESTful 风格接口开发。例如,通过 `@GetMapping(&quot;/user/{id}&quot;)` 可以将 URL 中的 `{id}` 参数自动映射到方法参数中。若参数名不一致,可通过 `@PathVariable(&quot;自定义名&quot;)` 指定绑定关系。此外,还支持多参数占位符,如 `/user/{id}/{name}`,分别映射到方法中的多个参数。运行项目后,访问指定 URL 即可验证参数是否正确接收。
345 0
|
7月前
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestMapping
@RequestMapping 是 Spring MVC 中用于请求地址映射的注解,可作用于类或方法上。类级别定义控制器父路径,方法级别进一步指定处理逻辑。常用属性包括 value(请求地址)、method(请求类型,如 GET/POST 等,默认 GET)和 produces(返回内容类型)。例如:`@RequestMapping(value = &quot;/test&quot;, produces = &quot;application/json; charset=UTF-8&quot;)`。此外,针对不同请求方式还有简化注解,如 @GetMapping、@PostMapping 等。
298 0
|
7月前
|
JSON 前端开发 Java
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RestController
本文主要介绍 Spring Boot 中 MVC 开发常用的几个注解及其使用方式,包括 `@RestController`、`@RequestMapping`、`@PathVariable`、`@RequestParam` 和 `@RequestBody`。其中重点讲解了 `@RestController` 注解的构成与特点:它是 `@Controller` 和 `@ResponseBody` 的结合体,适用于返回 JSON 数据的场景。文章还指出,在需要模板渲染(如 Thymeleaf)而非前后端分离的情况下,应使用 `@Controller` 而非 `@RestController`
229 0
|
3月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
200 0
|
3月前
|
SQL Java 数据库连接
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
117 0
|
3月前
|
JSON 前端开发 Java
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
180 0
|
9月前
|
SQL Java 数据库连接
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
387 29
|
10月前
|
设计模式 前端开发 Java
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
217 4