SpringMVC获取请求参数、域对象共享数据


一、SpringMVC获取请求参数

1、通过ServletAPI获取

  • 将HttpServletRequest作为控制器方法的形参,此时HttpServletRequest类型的参数表示封装了当前请求的请求报文的对象
<a th:href="@{/testServletAPI(username='admin',password=123456)}">测试使用servletAPI获取请求参数</a><br>
@Controller
public class ParamController {

    @RequestMapping("/testServletAPI")
    //形参位置的request表示当前请求
    public String testServletAPI(HttpServletRequest request){
        HttpSession session = request.getSession();
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        System.out.println("username:"+username+",password:"+password);
        return "success";
    }
}

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

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

<a th:href="@{/testParam(username='admin',password=123456)}">测试获取请求参数-->/testParam</a><br>
@RequestMapping("/testParam")
public String testParam(String username, String password){
	System.out.println("username:"+username+",password:"+password);
	return "success";
}

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

3、@RequestParam

@RequestParam是将请求参数和控制器方法的形参创建映射关系
@RequestParam注解一共有三个属性:
value:指定为形参赋值的请求参数的参数名
required:设置是否必须传输此请求参数,默认值为true

  • 若设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置defaultValue属性,则页面报错400:Required String parameter ‘xxx’ is not present;若设置为false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为null
  • defaultValue:不管required属性值为true或false,当value所指定的请求参数没有传输或传输的值为""时,则使用默认值为形参赋值
<form th:action="@{/testParam}" method="get">
    用户名:<input type="text" name="user_name"><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>

在这里插入图片描述

在这里插入图片描述

4、@RequestHeader

@RequestHeader是将请求头信息和控制器方法的形参创建映射关系
@RequestHeader注解一共有三个属性:value、required、defaultValue,用法同@RequestParam
在这里插入图片描述

5、@CookieValue

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

@RequestMapping("/request/cookie")
public String getCookie(
    
        // 使用 @CookieValue 注解获取指定名称的 Cookie 数据
        // name 或 value 属性:指定Cookie 名称
        // defaultValue 属性:设置默认值
        @CookieValue(value = "JSESSIONID", defaultValue = "missing") String cookieValue,
    
        // 形参位置声明 HttpSession 类型的参数即可获取 HttpSession 对象
        HttpSession session
) {
    
    log.debug("cookieValue = " + cookieValue);
    
    return "target";
}

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

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", 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;
    }
}
<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">
</form>
@RequestMapping("/testpojo")
public String testPOJO(User user){
	System.out.println(user);
	return "success";
}
//最终结果-->User{id=null, username='张三', password='123', age=23, sex='男',email='123@qq.com'}

7、POST请求的字符乱码问题

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

<!-- 配置过滤器解决 POST 请求的字符乱码问题 -->
<filter>
    <filter-name>CharacterEncodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    
    <!-- encoding参数指定要使用的字符集名称 -->
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    
    <!-- 请求强制编码 -->
    <init-param>
        <param-name>forceRequestEncoding</param-name>
        <param-value>true</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>

注1:在较低版本的 SpringMVC 中,forceRequestEncoding 属性、forceResponseEncoding 属性没有分开,它们是一个 forceEncoding 属性。这里需要注意一下。

注2:由于 CharacterEncodingFilter 是通过 request.setCharacterEncoding(encoding); 来设置请求字符集,所以在此操作前不能有任何的 request.getParameter() 操作。在设置字符集之前获取过请求参数,那么设置字符集的操作将无效。SpringMVC中处理编码的过滤器一定要配置到其他过滤器之前,否则无效

二、域对象共享数据

1、使用ServletAPI向request域对象共享数据

在这里插入图片描述

在这里插入图片描述

2、使用ModelAndView向request域对象共享数据

@RequestMapping("/testModelAndView")
public ModelAndView testModelAndView(){
	/**
	* ModelAndView有Model和View的功能
	* Model主要用于向请求域共享数据
	* View主要用于设置视图,实现页面跳转
	*/
	ModelAndView mav = new ModelAndView();
	//向请求域共享数据
	mav.addObject("testScope", "hello,ModelAndView");
	//设置视图,实现页面跳转
	mav.setViewName("success");
	return mav;
}

3、使用Model向request域对象共享数据

RequestMapping("/testModel")
public String testModel(Model model){
	model.addAttribute("testScope", "hello,Model");
	return "success";
}

4、使用map向request域对象共享数据

@RequestMapping("/testMap")
public String testMap(Map<String, Object> map){
	map.put("testScope", "hello,Map");
	return "success";
}

5、使用ModelMap向request域对象共享数据

@RequestMapping("/testModelMap")
public String testModelMap(ModelMap modelMap){
	modelMap.addAttribute("testScope", "hello,ModelMap");
	return "success";
}

6、Model、ModelMap、Map的关系

Model、ModelMap、Map类型的参数其实本质上都是 BindingAwareModelMap 类型的

public interface Model{}
public class ModelMap extends LinkedHashMap<String, Object> {}
public class ExtendedModelMap extends ModelMap implements Model {}
public class BindingAwareModelMap extends ExtendedModelMap {}

7、向session域共享数据

@RequestMapping("/testSession")
public String testSession(HttpSession session){
	session.setAttribute("testSessionScope", "hello,session");
	return "success";
}

在这里插入图片描述

8、向application域共享数据

@RequestMapping("/testApplication")
public String testApplication(HttpSession session){
	ServletContext application = session.getServletContext();
	application.setAttribute("testApplicationScope", "hello,application");
	return "success";
}

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值