Controller 接收请求参数的常见方式

  • Post author:
  • Post category:其他

Controller 接收请求参数的常见方式

  1. 通过实体bean接受请收参数
    public String login(User user,Model model){}
    适用于get、post提交请求方式
    bean的属性名称必须与请求参数名称相同
    Model model 用来给页面中返回数据 :model.addAttribute(“key”,value);
    页面中使用el表达式 ${key}
//实体bean
public class User{
	private String uname;
	public String getUname() {
		return uname;
	}
	public void setUname(String uname) {
		this.uname = uname;
	}
}
<!-- login.jsp页面: from表单 -->
<form method="post" action="user/login">
	<input type="text" name="uname">
	<input type="submit" value="登录">
</form>
${message}
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(User user,Model model){
		if("zhangsan".equals(user.getUname())){
			model.addAttrtibute("message","登录成功!");
			return "success";
		}else{
			model.addAttrtibute("message","登录失败,请重新登录!");
			return "login";
		}
	}
}
  1. 通过处理方法的形参接收请求参数
    public String login(String uname,Model model){}
    也就是直接把表单中的参数写在控制器类相应的方法的形参中
    形参名与请求参数名称完全相同(实体bean与html表单均参考方法1中的,以下同)
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(String uname,Model model){
		if("zhangsan".equals(uname)){
			model.addAttrtibute("message","登录成功!");
			return "success";
		}else{
			model.addAttrtibute("message","登录失败,请重新登录!");
			return "login";
		}
	}
}
  1. 通过HttpServletRequest接收请求参数
    适用于get、post提交请求方式
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(HttpServletRequest req,Model model){
		String name = req.getParameter("uname");
		if("zhangsan".equals(name)){
			model.addAttrtibute("message","登录成功!");
			return "success";
		}else{
			model.addAttrtibute("message","登录失败,请重新登录!");
			return "login";
		}
	}
}
  1. 通过@PathVariable接收URL中的请求参数
    @RequestMapping(value=”/login/{uname}”,method=“RequestMethod.Get”)
    访问路径http://localhost:8080/ch2/user/login/zhangsan
    自动将模板变量{uname}绑定到通过@PathVariable注解的同名参数上,即uname=zhangsan
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping(value="/login/{uname}",method="RequestMethod.Get")
	//必须加method属性
	public String login(@PathVariable String uname,Model model){
		if("zhangsan".equals(uname)){
			model.addAttrtibute("message","登录成功!");
			return "success";
		}else{
			model.addAttrtibute("message","登录失败,请重新登录!");
			return "login";
		}
	}
}
  1. 通过@RequestParam接收请求参数
    public String login(@RequestParam String uname,Model model){}
    适用于get、post提交请求方式
    与方法2通过处理方法的形参接收请求参数的区别:当请求参数名与接收参数名不一致时,此方法会报404错误,而方法2不会报404错误
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(@RequestParam String uname,Model model){
		if("zhangsan".equals(uname)){
			model.addAttrtibute("message","登录成功!");
			return "success";
		}else{
			model.addAttrtibute("message","登录失败,请重新登录!");
			return "login";
		}
	}
}
  1. 通过@ModelAttribute接收请求参数
    @ModelAttribute注解放在处理方法的形参上,用于将多个请求参数封装到一个实体对象,从而简化数据绑定流程,而且自动暴露为模型数据。
    (1)public String login(@ModelAttribute(“u”) User user){}
//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(@ModelAttribute("u") User user){
		if("zhangsan".equals(user.getUname())){
	        //使用@ModelAttribute("u")相当于使用model.addAttribute("u",user)
		    //页面中使用el表达式${u.uname}取出ModelAttribute中的uname值
			return "success";
		}else{
			return "login";
		}
	}
}

(2)public String login(@ModelAttribute User u){}

//控制器类
@Controller
@RequestMapping("/user")
public class UserController {
	@RequestMapping("/login")
	public String login(@ModelAttribute User u){
		if("zhangsan".equals(u.getUname())){
	        /* 使用@ModelAttribute User u相当于model.addAttribute("user",u)
	           默认model.addAttribute("user",user)中的key值为类名且首字母小写
		       页面中使用el表达式${user.uname}取出ModelAttribute中的uname值 */
			return "success";
		}else{
			return "login";
		}
	}
}

版权声明:本文为weixin_46141585原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。