SpringMVC学习笔记(四)—— SpringMVC获取请求参数

04、SpringMVC获取请求参数

4.1、通过ServletAPI获取

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

test_param.html

<a th:href="@{/testServletAPI(username='admin',password='123456')}">测试使用ServletAPI获取请求参数</a>

ParamController.java

@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";
}

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

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

2、代码演示:

①参数名称不一致的情况:

test_param.html

<a th:href="@{/testParam(username='admin',password='123456')}">测试使用控制器的形参获取请求参数</a><br/>

ParamController.java

@RequestMapping("/testParam")
public String testParam(String username, String password) {
    System.out.println("username="+username+",password="+password);
    return "success";
}

②参数名称相同的情况:

例如:复选框的情况

test_param.html

<form th:action="@{/testParam}" method="post">
    用户名:<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>

ParamController.java

@RequestMapping("/testParam")
public String testParam(String username, String password, String hobby) {
    //若请求参数中出现多个同名的请求参数,可以在控制器方法的形参位置设置一个字符串类型或字符串数组来接收此请求参数
    //若使用字符串类型的形参,最终结果为请求参数的每一个值之间使用逗号拼接
    System.out.println("username="+username+",password="+password+",hobby="+hobby);
    return "success";
}

1、结果是复选框的选择用逗号拼接成一个字符串,如username=admin, password=111111, hobby=a,b

2、也可以将控制器的形参类型换成数组进行获取,如:String[] hobby,获取的结果为:username=admin,password=111111,hobby=[a, b]

3、注意:

  • 若请求所传输的请求参数中有多个同名的请求参数,此时可以在控制器方法的形参中设置字符串
  • 数组或者字符串类型的形参接收此请求参数 若使用字符串数组类型的形参,此参数的数组中包含了每一个数据
  • 若使用字符串类型的形参,此参数的值为每个数据中间使用逗号拼接的结果

4.3、@RequestParam

1、@RequestParam

  • @RequestParam是将请求参数控制器方法的形参创建映射关系 。
  • @RequestParam注解一共有三个属性:
    • value:指定为形参赋值的请求参数的参数名
    • required:设置是否必须传输此请求参数,默认值为true
      • 若设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置 defaultValue属性,则页面报错400:Required String parameter 'xxx' is not present
      • 若设置为 false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为 null
    • defaultValue:不管required属性值为truefalse,当value所指定的请求参数没有传输或传输的值为""时,则使用默认值为形参赋值。

2、代码演示:

ParamController.java

@RequestMapping("/testParam")
public String testParam(
        @RequestParam(value = "user_name",required = false,defaultValue = "hehe") String username,
        String password,
        String[] hobby) {
    System.out.println("username="+username+",password="+password+",hobby="+ Arrays.toString(hobby));
    return "success";
}

4.4、@RequestHeader

1、@RequestHeader

  • @RequestHeader是将请求头信息控制器方法的形参创建映射关系
  • @RequestHeader注解一共有三个属性:(用法同@RequestParam)
    • value
    • required
    • defaultValue

2、代码演示:

ParamController.java

@RequestMapping("/testParam")
public String testParam(
        @RequestHeader(value = "sayhaha",required = true,defaultValue = "haha") String host) {
    System.out.println("host:" + host);
    return "success";
}

4.5、@CookieValue

1、@CookieValue

  • @CookieValue是将**cookie数据控制器方法的形参**创建映射关系
  • @CookieValue注解一共有三个属性:(用法同@RequestParam)
    • value
    • required
    • defaultValue

2、注意:

Session技术依赖于Cookie技术

Cookie是客户端会话技术,Session是服务器端会话技术

3、通过ServletAPI创建session

HttpSession session = request.getSession();

注意:cookie会话技术默认的生命周期是浏览器开启到浏览器关闭

4、代码演示:

ParamController.java

@RequestMapping("/testParam")
public String testParam(
        @CookieValue(value = "JSESSIONID",required = false, defaultValue = "11") String JSESSIONID) {

    System.out.println("JSESSIONID" + JSESSIONID);
    return "success";
}

4.6、通过POJO获取请求参数

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

2、代码演示:

test_param.html

<form th:action="@{/testBean}" 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="使用实体类接收请求参数">
</form>

User.java

package com.ssm.mvc.bean;

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 + '\'' +
                '}';
    }
}

ParamController.java

@RequestMapping("/testBean")
public String testBean(User user) {
    System.out.println(user);
    return "success";
}

注意:

最终结果为:User{id=null, username=‘admin’, password=‘123456’, age=23, sex=‘???’, email=‘123@123.com’}

其中,sex的结果出现了乱码问题

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

1、出现乱码问题的原因是:字符编码不一致

2、原始解决乱码问题的方法:

request.setCharacterEncoding("UTF-8");

注意:在当前controller中如此设置编码,此时DispatcherServlet已经获取了参数,且参数中已经为乱码,所以当前controller设置编码已经失去作用。

因此需要在DispatcherServlet执行前进行设置编码。

3、获取请求参数出现的乱码问题分为两种:

  • 第一种是"get"请求出现的乱码:

    • 此乱码是由tomcat造成的

    • 解决方法:是在tomcat下的配置文件server.xml中设置编码

      <Connector port="8080" protocol="HTTP/1.1"
                     connectionTimeout="20000"
                     redirectPort="8443" 
      			   URIEncoding="utf-8"/>
      
  • 第二种是"post"请求出现的乱码

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

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>

最终结果为:User{id=null, username=‘admin’, password=‘123456’, age=23, sex=‘男’, email=‘123@123.com’}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SpringMVC获取请求参数的方式有多种,最常用的是通过注解@RequestParam获取请求参数。例如,@RequestParam("username") String username表示获取名为username的请求参数,并将其赋值给String类型的变量username。另外,还可以通过HttpServletRequest对象获取请求参数,例如HttpServletRequest.getParameter("username")。此外,还可以使用@PathVariable注解获取URL路径中的参数,例如@RequestMapping("/user/{id}"),其中{id}表示获取路径中的id参数。 ### 回答2: SpringMVC是一种基于Java的web框架,用于开发web应用程序。通过SpringMVC框架,可以很方便地获取请求参数。 在SpringMVC中,获取请求参数有多种方式。其中,最常用的方式是通过方法的参数获取请求参数。在控制器方法中定义参数参数名与请求参数名一致,SpringMVC会自动将请求参数的值绑定到对应的参数上。例如,如果请求中有一个参数名为"username"的参数,可以在控制器方法中定义一个同名的String类型的参数来接收该参数的值。 除了通过方法参数获取请求参数,还可以使用@RequestParam注解。该注解可以用于方法参数上,指定请求参数的名称,以及是否为必需的参数。例如,@RequestParam("id") int userId,表示要获取名为"id"的请求参数,并将其转换为int类型的userId参数。可以通过设置required属性来指定该参数是否必需,默认为true,如果请求中没有该参数,会抛出异常。 另外,还可以使用@PathVariable注解来获取路径参数。路径参数是在URL中定义的参数,可以通过在控制器方法的路径中使用占位符来表示。例如,@RequestMapping("/user/{id}"),可以通过@PathVariable("id")来获取路径中的参数值。 除了以上方式,还可以通过HttpServletRequest对象来获取请求参数。在控制器方法中,可以将HttpServletRequest对象作为方法参数传入,然后通过该对象的getParameter方法来获取请求参数的值。 总之,SpringMVC提供了多种简便的方式来获取请求参数。无论是通过方法参数、@RequestParam注解、@PathVariable注解,还是使用HttpServletRequest对象,都可以方便地获取请求参数的值,便于进行后续的业务逻辑处理。 ### 回答3: SpringMVC是基于Java的一种MVC(Model-View-Controller)框架,用于构建Web应用程序。在SpringMVC中,获取请求参数是非常常见的任务并且非常容易。 首先,要使用SpringMVC获取请求参数,你需要定义一个处理请求的控制器类,并在类的方法上添加@RequestMapping注解来指定请求的URL映射。 在控制器方法中,你可以使用@RequestParam注解来获取请求参数。该注解有几个属性可以使用,最常用的是value属性,用于指定请求参数的名称。例如,你可以使用@RequestParam("name")来获取名为name的请求参数。如果请求参数的名称与方法参数的名称相同,你也可以省略value属性,只使用@RequestParam注解。 @RequestParam注解也支持一些其他属性,例如required属性用于指示请求参数是否是必需的,默认为true,即必须提供该参数。你还可以使用defaultValue属性来指定请求参数的默认值。 除了@RequestParam注解,你还可以使用@PathVariable注解来获取URL路径中的参数。该注解将URL中的占位符与方法参数进行映射。例如,如果URL中有一部分为"/users/{id}",你可以在方法参数中使用@PathVariable("id")来获取该路径中的id参数。 另外,SpringMVC还支持通过@RequestParamMap注解来获取所有的请求参数,并以Map的形式进行处理。这对于处理不确定数量的请求参数非常有用。 总而言之,SpringMVC提供了多种方法来获取请求参数。你可以使用@RequestParam注解来获取单个请求参数,使用@PathVariable注解来获取URL路径中的参数,或者使用@RequestParamMap注解来获取所有的请求参数。这些功能使得处理请求参数变得非常方便和灵活。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值