session和model问题导致登录无法正常退出
session和model问题导致登录无法正常退出
问题
用ssm+maven+jsp+eclipse做了一个登录注册功能,本来是没问题的,但是我又做了一个‘暂不登录’按钮,就……。当点击退出之后,发现没有退出。这里主要讲一下登录问题。少逼逼,看代码。
下面是controller中的登录和退出功能。
1、注意看在第2行我用了一个@SessionAttributes。在验证登录方法里面我用了一个model.addAttribute(“user”,user);
2、注意看我退出登录方法里面我用了session.invalidate();和session.removeAttribute(“user”);当然这两种方法都是没法让我退出的。问题就出在这,下面有分析。先说解决方法:使用sessionStatus.setComplete();成功退出。
@Controller
@SessionAttributes("user")
public class LoginController {
@Autowired
private LoginService loginService;
//表单提交过来的路径
@RequestMapping("/checkLogin")
//@ModelAttribute
public String checkLogin(@ModelAttribute("abc")User user,Model model){
//调用service方法
user = loginService.checkLogin(user.getUsername(), user.getPassword());
//若有user则添加到model里并且跳转到首页页面
if(user != null){
model.addAttribute("user",user);
return "redirect:/user/index.do";
}
return "login";
}
//注销方法
@RequestMapping("/outLogin")
public String outLogin(HttpSession session,SessionStatus sessionStatus){
//通过session.invalidata()方法来注销当前的session
sessionStatus.setComplete();
//session.invalidate();
//session.removeAttribute("user");
return "redirect:/checkLogin.do";
}
}
下面是部分jsp页面代码。主要看第三行:页面获取session值的方法。如果获取不了就表示退出成功了。
<%-- 测试能够获取session
<div>
<strong> ${sessionScope.user.username}!!!!! </strong>
<strong> ${user.username}????? </strong>
</div>
--%>
<c:choose>
<c:when test="${!empty user.username}">
<li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown">${user.username} <strong class="caret"></strong></a>
<ul class="dropdown-menu">
<li><a href="<%=request.getContextPath() %>/user/toUserDetail.do?id=${user.id}">个人信息</a></li>
<li class="divider"></li>
<li><a href="<%=request.getContextPath() %>/outLogin.do">退出</a></li>
</ul></li>
</c:when>
<c:otherwise>
<li><a href="<%=request.getContextPath() %>/user/toLogin.do">登录</a>
<li><a href="<%=request.getContextPath() %>/user/toRegedit.do">注册</a>
</c:otherwise>
</c:choose>
贴出来的代码是解决了问题的代码,能够正常退出了。
下面展示一些service层的代码。
@Service
public class LoginServiceImpl implements LoginService{
@Autowired
private UserMapper userMapper;
@Override
public User checkLogin(String username, String password) {
User user = userMapper.findByUsername(username);
if(user != null && user.getPassword().equals(password)){
return user;
}
return null;
}
}
分析
询问某个好哥哥,他叫我去了解一下model对象。查阅资料整理如下:
1、model就等于普通request的setAttribute,模型层存,视图层取。但request只是一次请求完了就完了。
2、session有两种,一种就是直接传递httpsession,还有一种就是我这样用@sessionAttribute注解,用了这个注解他会把model中对应的属性名自动保存到session。就是在加载@controller之后,渲染view之前。然后清除就要用httpsession的remove去清除。
3、我这次的解决办法就是用sessionStatus.setComplete()来清除。
参考资料:
https://www.cnblogs.com/xiaohuihui96/archive/2016/12/12/6161140.html
https://www.logicbig.com/tutorials/spring-framework/spring-web-mvc/spring-model-attribute-with-session.html
虽然问题解决了,但是还是有很多疑问有待自我解决:比如${sessionScope.user.username}和 ${user.username}到底有啥区别?一个是从session里取值,一个从model里取?如果是这样,sessionStatus.setComplete()把session和model都清除了?原来测试都是退出后马上登陆下一个账户没有发现这个问题。那就是说session或model只能存一个user对吧?
初次分析,还望多多指教,多多包涵。