HttpServletRequest中的request.setAttribute()和request.getSession().setAttribute()

1、request.setAttribute(“num”,value);
有效范围是一个请求范围,不发送请求的界面无法获取到value的值,jsp界面获取使用EL表达式${num};
只能在一个request内有效,如果重定向客户端,将取不到值。

request在当次的请求的URL之间有效,比如,你在请求某个servlet,那么你提交的信息,可以使用request.getAttribute()方式获得,而当你再次跳转之后,这些信息将不存在。

2、request.getSession().setAttribute(“num”,value);
有效范围是一个session周期,在session过期之前或者用户关闭页面之前是有效的,jsp界面获取使用EL表达式${num};
可以通过sessionID得到自己的session,将参数存储在session中,即使重定向客户端也没事,这个值可以在多个页面上使用。

比如访问一个网站,登录后用户信息被保存到session中,在session过期之前或者用户关闭页面之前,用户信息可以通过request.getSession().getAttribute()方式获得。

帮我看看以下代码有问题吗:@PostMapping("/userLogin") public String userLogin(@RequestParam("username") String username,@RequestParam("password") String password,@RequestParam("character") String character, HttpServletRequest request, HttpServletResponse response,HttpSession session) { //登录方法 if (StringUtils.isEmpty(username)) { request.setAttribute("error","请输入用户名");return "login";} if (StringUtils.isEmpty(password)) { request.setAttribute("error","请输入密码");return "login";} if (StringUtils.isEmpty(character)) { request.setAttribute("error","请勾选身份");return "login";} //判断输入的内容是否为空 if (!username.matches("[a-zA-Z0-9_]{6,20}")) { request.setAttribute("error", "用户名长度应为6-20个字符, 只能包含字母、数字下划线"); return "login"; } if (!password.matches("[a-zA-Z0-9_]{6,20}")) { request.setAttribute("error", "密码长度应为6-20个字符, 只能包含字母、数字下划线"); return "login"; } // 验证用户名密码的长度格式 if(character.equals("1")){//判断登录角色是买家还是卖家 Buyer buyer= buyerService.buyerLogin(username,password); if(buyer != null) { request.getSession().setAttribute("buyer",buyer);//将买家信息保存到session request.setAttribute("success","登录成功");return "applianceby";//买家登录} request.setAttribute("error","用户名或密码不正确,请重试");return "login"; }else{Seller seller= sellerService.sellerLogin(username,password); if(seller != null) { request.getSession().setAttribute("seller",seller); //将卖家信息保存到session request.setAttribute("success","登录成功");return "appliancesl";//卖家登录} request.setAttribute("error","用户名或密码不正确,请重试");return "login";}}
07-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值