Flask接口签名sign原理与实例代码浅析
301
2022-08-04
SpringMVC获取请求参数笔记整理(spring mvc 接收请求参数)
目录前言一、使用ServletAPI获取参数二、通过控制器方法的形参获取请求参数三、@RequestParam四、@RequestHeader五、@CookieValue六、通过实体类的形参获取参数
前言
本篇文章目的是为了学习、记录和分享博主在学习 Spring MVC过程中的笔记。同时也希望本篇文章能够帮助屏幕前的你!
一、使用ServletAPI获取参数
通过 HttpServletRequest 当作形参,此时 HttpServletRequest 类型的参数表示封装了当前请求的请求报文的对象。
测试案例:
@RequestMapping("/testParam")
public String testParam(HttpServletRequest request){
String username = request.getParameter("username");
String password = request.getParameter("password");
System.out.println("username:"+username+",password:"+password);
return "success";
}
username:
password:
运行结果:
二、通过控制器方法的形参获取请求参数
在控制器方法的形参位置,设置和请求参数同名的形参,当浏览器发送请求,匹配到请求映射时,在 MUNcsHZVDispatcherServlet 中就会将请求参数赋值给相应的形参。
测试用例:
@RequestMapping("/testParam")
public String testParam(String username,String password){
System.out.println("username:"+username+",password:"+password);
return "success";
}
username:
password:
运行结果:
三、@RequestParam
@RequestParam是将请求参数和控制器方法的形参创建映射关系!
OK,我们可以来看一下 @RequestParam 的源码部分:
@Target({ElementType.PARAMETER})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface RequestParam {
//别名name,一般默认为空
@AliasFor("name")
String value() default "";
//指定为形参赋值的请求参数的参数名
@AliasFor("value")
String name() default "";
//设置是否必须传输此请求参数,默认值为true
boolean required() default true;
//用来定义默认值
String defaultValue() default "\n\t\t\n\t\t\n\ue000\ue001\ue002\n\t\t\t\t\n";
}
注:
若required设置为true时,则当前请求必须传输value所指定的请求参数,若没有传输该请求参数,且没有设置defaultValue属性,则页面报错 400:Required String parameter ‘xxx’ is not present; 若设置为false,则当前请求不是必须传输value所指定的请求参数,若没有传输,则注解所标识的形参的值为null。
@RequestMapping(value = "/testParam", method = RequestMethod.POST)
public String testParam(@RequestParam(value = "user_name",MUNcsHZVrequired = false,defaultValue = "gg") String name,
@RequestParam(value = "password",required = true,defaultValue = "hh") String pwd,
String[] hobby) {
System.out.println(name + pwd + Arrays.toString(hobby));
return "success";
}
用户名:
密码:
爱好:a
b
c
运行结果:
四、@RequestHeader
@RequestHeader是将请求头信息和控制器方法的形参创建映射关系。
@RequestHeader注解一共有三个属性:value、required、defaultValue,用法同@RequestParam。
@RequestMapping(value = "/testParam2",method = RequestMethod.POST)
//形参位置的request表示当前请求
public String testParam2(@RequestParam("username") String name,
@RequestParam("password") String pwd,
String[] hobby,
@RequestHeader("Host") String host){
System.out.println(name+pwd+ Arrays.toString(hobby));
System.out.println("Host:"+host);//输出结果Host:localhost:8080
return "success";
}
五、@CookieValue
@CookieValue是将cookie数据和控制器方法的形参创建映射关系
@CookieValue注解一共有三个属性:value、required、defaultValue,用法同@RequestParam
@CookieValue("jsESSIONID") String JSESSIONID
@Controller
@RequestMapping("hello")
public class HelloController2 {
@RequestMapping("show25")
public String test25(Model model, @CookieValue("JSESSIONID")String jsessionid){
model.addAttribute("msg", "获取cookie,jsessionid:" + jsessionid);
return "hello2";
}
}
六、通过实体类的形参获取参数
首先需要创建一个实体类 User
package xiaobao.mvc.bean;
public class User {
private Integer id;
private String username;
private String password;
private Integer age;
private String sex;
private String 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 + '\'' +
'}';
}
然后前端:
用户名:
密码:
性别:男女
年龄:
邮箱:
后端:
@RequestMapping("/testpojo")
public String testPOJO(User user){
System.out.println(user);
return "success";
}
运行结果:
因为我还没没有解决乱码,所以这个就一直乱码问题,等到后面我专门出一期这个文章来解决乱码的问题!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~