1、通过ServletAPI获取

将HttpServletRequest作为控制器方法的形参,此时HttpServletRequest类型的参数表示封装了当前请求的请求报文的对象

<a th:href="@{/testServletAPI(username='admin',password=123456)}" rel="external nofollow" >测试使用testServletAPI获取请求参数</a>
    @RequestMapping("/testServletAPI")
    //形参位置的request就表示当前请求
    public String testServletAPI(HttpServletRequest request){
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        System.out.println("username:" username ",password:" password);
        return "success";
    }

输出:username:admin,password:123456

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

在控制器方法的形参位置,设置和请求参数同名的形参,当浏览器发送请求,匹配到请求映射时,在DispatcherServlet中就会将请求参数赋值给相应的形参

常见:

<a th:href="@{/testParam(username='admin',password=123456)}" rel="external nofollow" >测试通过控制器方法的形参获取请求参数</a><br>
    @RequestMapping("/testParam")
    //必须保证形参名和请求传递的参数名一致
    public String testParam(String username, String password){
        System.out.println("username:" username ",password:" password);
        return "success";
    }

有多个同名参数(例如复选框):

<form th:action="@{/testParam}" method="get">
    用户名:<input type="text" name="username"><br>
    密码:<input type="password" name="password"><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>
    @RequestMapping("/testParam")
    //必须保证形参名和请求传递的参数名一致
    public String testParam(String username, String password,String hobby){
        System.out.println("username:" username ",password:" password ",hobby:" hobby);
        return "success";
    }
    @RequestMapping("/testParam")
    //必须保证形参名和请求传递的参数名一致
    public String testParam(String username, String password,String[] hobby){
        System.out.println("username:" username ",password:" password ",hobby:"  Arrays.toString(hobby));
        return "success";
    }

注:

若请求所传输的请求参数中有多个同名的请求参数,此时可以在控制器方法的形参中设置字符串数组或者字符串类型的形参接收此请求参数

若使用字符串数组类型的形参,此参数的数组中包含了每一个数据:hobby:[a, b]

若使用字符串类型的形参,此参数的值为每个数据中间使用逗号拼接的结果:hobby:a,b

3、@RequestParam

@RequestParam是将请求参数和控制器方法的形参创建映射关系

    @RequestMapping("/testParam")
    //当形参名和请求参数名不一致时,通过注解@RequestParam绑定形参和请求参数
    public String testParam(
            @RequestParam("username") String user_name,
            String password,
            String[] hobby){
        System.out.println("user_name:" user_name ",password:" password ",hobby:"  Arrays.toString(hobby));
        return "success";
    }

输出:user_name:admin,password:123456,hobby:[a, b, c]

@RequestParam注解一共有三个属性:

value:指定为形参赋值的请求参数的参数名

required:设置是否必须传输此请求参数,默认值为true

若设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置defaultValue属性,则页面报错400:Required String parameter 'xxx' is not present;

若设置为false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为null

defaultValue:不管required属性值为true或false,当value所指定的请求参数没有传输或传输的值为""时,则使用默认值为形参赋值

4、@RequestHeader

@RequestHeader是将请求头信息和控制器方法的形参创建映射关系

    @RequestMapping("/testParam")
    //当形参名和请求参数名不一致时,通过注解@RequestParam绑定形参和请求参数
    public String testParam(
            @RequestParam("username") String user_name,
            String password,
            String[] hobby,
            //通过注解@RequestHeader将请求头信息和控制器方法的形参创建映射关系
            @RequestHeader("Host") String host){
        System.out.println("user_name:" user_name ",password:" password ",hobby:"  Arrays.toString(hobby));
        System.out.println("host:" host);
        return "success";
    }

输出:

user_name:admin,password:123456,hobby:[a, b, c]

host:localhost:8080

@RequestHeader注解一共有三个属性:value、required、defaultValue,用法同@RequestParam

5、@CookieValue

@CookieValue是将cookie数据和控制器方法的形参创建映射关系

    @RequestMapping("/testParam")
    //当形参名和请求参数名不一致时,通过注解@RequestParam绑定形参和请求参数
    public String testParam(
            @RequestParam("username") String user_name,
            String password,
            String[] hobby,
            //通过注解@RequestHeader将请求头信息和控制器方法的形参创建映射关系
            @RequestHeader("Host") String host,
            //通过注解@CookieValue将cookie数据和控制器方法的形参创建映射关系
            @CookieValue("JSESSIONID") String JSESSIONID){
        System.out.println("user_name:" user_name ",password:" password ",hobby:"  Arrays.toString(hobby));
        System.out.println("host:" host);
        System.out.println("JSESSIONID:" JSESSIONID);
        return "success";
    }

输出:

user_name:admin,password:123456,hobby:[a, b, c]

host:localhost:8080 JSESSIONID:005A829F9D7222CEA96E9EF6F86B8F58

@CookieValue注解一共有三个属性:value、required、defaultValue,用法同@RequestParam

6、通过POJO获取请求参数

可以在控制器方法的形参位置设置一个实体类类型的形参,此时若浏览器传输的请求参数的参数名和实体类中的属性名一致,那么请求参数就会为此属性赋值

public class User {
    private Integer id;
    private String username;
    private String password;
    private Integer age;
    private String sex;
    private String email;
    public User() {
    }
    public User(Integer id, String username, String password, Integer age, String sex, String email) {
        this.id = id;
        this.username = username;
        this.password = password;
        this.age = age;
        this.sex = sex;
        this.email = email;
    }
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    public Integer getAge() {
        return age;
    }
    public void setAge(Integer age) {
        this.age = age;
    }
    public String getSex() {
        return sex;
    }
    public void setSex(String sex) {
        this.sex = sex;
    }
    public String getEmail() {
        return email;
    }
    public void setEmail(String email) {
        this.email = email;
    }
    @Override
    public String toString() {
        return "User{"  
                "id="   id  
                ", username='"   username   '\''  
                ", password='"   password   '\''  
                ", age="   age  
                ", sex='"   sex   '\''  
                ", email='"   email   '\''  
                '}';
    }
}
<form th:action="@{/testPojo}" method="get">
    用户名:<input type="text" name="username"><br>
    密码:<input type="password" name="password"><br>
    性别:<input type="radio" name="sex" value="男">男<input type="radio" name="sex" value="女">女<br>
    年龄:<input type="text" name="age"><br>
    邮箱:<input type="text" name="email"><br>
    <input type="submit" value="测试通过POJO获取请求参数">
</form>
    @RequestMapping("/testPojo")
    public String testPOJO(User user){
        System.out.println(user);
        return "success";
    }

输出:User{id=null, username='admin', password='123', age=22, sex='男', email='125jugyg@163.com'}

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

上述通过POJO获取请求参数时,如果使用get方式不会乱码(Tomcat8以上已经解决了get乱码问题),但是使用post方式获取时还是会乱码

<form th:action="@{/testPojo}" method="post">
    用户名:<input type="text" name="username"><br>
    密码:<input type="password" name="password"><br>
    性别:<input type="radio" name="sex" value="男">男<input type="radio" name="sex" value="女">女<br>
    年龄:<input type="text" name="age"><br>
    邮箱:<input type="text" name="email"><br>
    <input type="submit" value="测试通过POJO获取请求参数">
</form>

输出:

User{id=null, username='admin', password='123', age=22, sex='ç·', email='125jugyg@163.com'}

解决获取请求参数的乱码问题,可以使用SpringMVC提供的编码过滤器CharacterEncodingFilter,但是必须在web.xml中进行注册

    <!--配置springMVC的编码过滤器-->
    <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>forceResponseEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>CharacterEncodingFilter</filter-name>
<!--        所有请求地址均可用-->
        <url-pattern>/*</url-pattern>
    </filter-mapping>

再次发送post请求无乱码

User{id=null, username='张三', password='123456', age=22, sex='男', email='125jugyg@163.com'}

到此这篇关于SpringMVC实现获取请求参数方法详解的文章就介绍到这了,更多相关SpringMVC获取请求参数内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

SpringMVC实现获取请求参数方法详解的更多相关文章

  1. vue3获取当前路由地址

    本文详细讲解了vue3获取当前路由地址的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. AngularJS数据源的多种获取方式汇总

    在AngularJS中获取数据源的方式有很多种,本文给大家整理几种获取数据源的方式,对angularjs获取数据源的方式相关知识感兴趣的朋友一起学习吧

  3. 使用sockets:从新闻组中获取文章(三)

    >我们从服务器的这个新闻组中读取了最后的十篇文章,。也可以通过使用HEAD命令读取文章的头信息,或者使用BODY命令读取文章内容。>关于fclose()的更多信息,请参考http://www.php.net/manual/function.fclose.php结论在上文中,我们看到了怎样打开、使用然后关闭一个socket:连接到一个NNTP服务器,取回一些文章。使用POST命令发表文章也复杂不到哪儿去。下一步就是编写一个基于WEB的新闻组客户端了。这样,你有了一个基于web的搜索新闻组的程序了。

  4. JSP中springmvc配置validator的注意事项

    这篇文章主要介绍了JSP中springmvc配置validator的注意事项的相关资料,并说明springmvc中spring-servlet.xml、applicationContext.xml的区别需要的朋友可以参考下

  5. SpringMVC拦截器和异常处理器使用示例超详细讲解

    拦截器(Interceptor)是一种动态拦截方法调用的机制,在SpringMVC中动态拦截控制器方法的执行。本文将详细讲讲SpringMVC中拦截器参数及拦截器链配置,感兴趣的可以尝试一下

  6. Java获取Excel中图片所在的行和列坐标位置

    这篇文章主要介绍了Java获取Excel中图片所在的行和列坐标位置,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下

  7. SpringMVC数据页响应ModelAndView实现页面跳转

    本文主要介绍了SpringMVC数据页响应ModelAndView实现页面跳转,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  8. SpringMVC静态资源配置过程详解

    在javaweb项目中配置了DispatcherServlet的情况下,如果不进行额外配置的话,几乎所有的请求都会走这个servlet来处理,默认静态资源按路径是访问不到的会报404错误,下面就来讲一讲如何配置才能访问到静态资源吧

  9. vue中this.$http.post()跨域和请求参数丢失的解决

    这篇文章主要介绍了vue中this.$http.post()跨域和请求参数丢失的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  10. 详解SpringMVC中的四种跳转方式、视图解析器问题

    这篇文章主要介绍了SpringMVC的四种跳转方式、视图解析器,springmvc核心配置文件和视图解析器的使用,添加视图解析器,通过案例讲解四种跳转方式,需要的朋友可以参考下

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部