springMVC实现登陆
- 页面打开跳转到登陆页面
- 登陆成功跳转到成功页面
- 登陆失败再次返回登录页面,并增加提示信息
1、首页跳转到登陆页面
Tomcat服务器启动时默认加载WEB-INF下的index.jsp,可以通过修改xml配置的方式来改变Tomcat这一默认行为。这里使用springMVC来实现这个功能。
第一种实现方案是配置Controller,value值配成空字符串或者login,这样在访问8080端口或者直接输入login的时候回跳转到login.jsp。
@RequestMapping(value = {"","login"},method = RequestMethod.GET) public String login(){ return "login"; }
第二种是在springMVC配置文件里用XML的形式来实现上述结果。
<mvc:view-controller path="/" view-name="login"/> <mvc:view-controller path="login" view-name="login"/>
2、页面跳转
这里只关注页面跳转的实现,用户验证暂不考虑。
首先考虑登陆失败用什么样的方式回到login页面,重定向?转发?还是直接返回一个login字符串再解析一次?分别实验
2.1 返回字符串
如下所示,当用户认证不通过的时候返回login作为视图名,经由第一步配置的Controller直接再次调回到主页。
@RequestMapping(value = "doLogin",method = RequestMethod.POST) public String login(HttpServletRequest request, @RequestParam("email")String email, @RequestParam("password")String password ){ User user = userService.login(email, password); ModelAndView modelAndView = new ModelAndView(); if (user!=null && user.getPassword().equals(password)){ modelAndView.addObject("user",user); modelAndView.setViewName("success"); return "redirect:/success"; }else { //request.setAttribute("wrongMsg","用户名密码错误"); //request.getSession().setAttribute("wrongMsg","用户名密码错误"); return "login"; } }
这样做是能够实现直接跳转到主页的,但问题在于跳回到主页后url地址栏显示的仍是doLogin即前端表单提交的地址。这样首先让我感觉不舒服,我登陆页面应该是login为什么登陆失败跳到doLogin?其次这样不安全,多次刷新登陆失败后的doLogin会产生表单重复提交。
2.2 forward
把return改成"redirect:/logim"。产生的效果和上面直接返回字符串一样,失败后的页面也是doLogin,问题也同上。其实仔细想想,这两种方式后台的处理结果理应相同,返回String字符串,封装成ModelAndView对象,找到视图解析器,返回结果;返回forward,也是找到处理"login"请求的字符串,然后重复上面的结果。
2.3 redirect
总言而之上面两个都不是我想要的结果,我想要的结果是登陆失败后url地址栏里仍然是login,而不是doLogin。
@RequestMapping(value = "doLogin",method = RequestMethod.POST) public String login(HttpServletRequest request, @RequestParam("email")String email, @RequestParam("password")String password ){ User user = userService.login(email, password); ModelAndView modelAndView = new ModelAndView(); if (user!=null && user.getPassword().equals(password)){ modelAndView.addObject("user",user); modelAndView.setViewName("success"); return "redirect:/success"; }else { request.setAttribute("wrongMsg","用户名密码错误"); request.getSession().setAttribute("wrongMsg","用户名密码错误"); return "redirect:/login"; } }