RedirectAttributes是Spring mvc 3.1版本之后出来的一个功能,专门用于重定向之后还能带参数跳转的
他有两种带参的方式:
RedirectAttributes attr
第一种:
attr.addAttribute("param", value);
这种方式就相当于重定向之后,在url后面拼接参数,这样在重定向之后的页面或者控制器再去获取url后面的参数就可以了,但这个方式因为是在url后面添加参数的方式,所以暴露了参数,有风险
第二种:
attr.addFlashAttribute("param", value);
这种方式也能达到重新向带参,而且能隐藏参数,其原理就是放到session中,session在跳到页面后马上移除对象。所以你刷新一下后这个值就会丢掉
例:
@RequestMapping("/redirect")
public String redirectTest(RedirectAttributes attr){
attr.addAttribute("userName", "root");
attr.addFlashAttribute("password","123456");
return "redirect:/book/getbook";
}
@RequestMapping("/getbook")
@ResponseBody
public String getBook( ModelMap map, @ModelAttribute("password") String password1,
@RequestParam(value = "password",required = falses ) String password2
HttpServletRequest request,@RequestParam("userName") String userName,){
System.out.println("userName : "+map.get("userName")) //null
System.out.println("userName1 :" + request.getAttribute("userName")); //null
System.out.println("userName2 :" + request.getParameter("userName")); //root
System.out.println("userName3 : " + userName); //root
//取
System.out.println("password : "+map.get("password")); // 123456
System.out.println("password1 :" + request.getAttribute("password")); //null
System.out.println("password2 :" + request.getParameter("password")); //null
System.out.println("password3 : " + password2); //null
System.out.println("password3 : " + password1); // 123456
RequestContextUtils.getInputFlashMap(request).get("password");//123456
return "result";
}
请求结果
url : http://localhost:9019/book/getbook?userName=root
总结:
请求转发需要携带参数时
1、使用 RedirectAttributes 的 addAttribute()方法设置参数,则参数将直接拼接在转发url后面,然后可以在通过request.getParameter("userName")) 和 直接通过spring mvc配置参数映射接收到参数
2、使用 RedirectAttributes 的 addFlashAttribute()方法设置参数,则参数不会出现在转发url中,然后可以通过modelMap 取出参数
3、使用modelMap,modelAttribute以及RequestContextUtils.getInputFlashMap(request).get("key")都可以获取到RedirectAttributes设置的值
补充:
请求结果页面代码
result welcome in $!{title}; ${userName}; ${password}
结果