登陆判断验证

本文详细介绍了如何在SpringMVC应用中实现用户登录验证拦截,包括登录页面、Controller处理、success页面展示以及使用LoginInterceptor进行拦截。通过登录状态管理,确保只有登录用户才能访问成功页面。

登陆判断验证


1、设计思路

  • 首页有登录和登录成功
  • 未登录不能进入登陆成功
  • 写一个拦截器实现第二条
  • 拦截器中拦截后转发到登陆页面

2、测试

1、编写登陆页面 login.jsp
  • 放在WEB-INF下安全
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
   <title>Title</title>
</head>

<h1>登录页面</h1>
<hr>

<body>
<form action="${pageContext.request.contextPath}/user/login">
  用户名:<input type="text" name="username"> <br>
  密码:<input type="password" name="pwd"> <br>
   <input type="submit" value="提交">
</form>
</body>
</html>
2、编写controller处理请求
  • session储存用户信息,生命周期在整个浏览器访问的时候
package com.kuang.controller;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpSession;

@Controller
@RequestMapping("/user")
public class LoginController {

    //跳转到登陆页面
    @RequestMapping("/jumplogin")
    public String jumpLogin(){
        return "login";
    }

    //跳转到成功页面
    @RequestMapping("/jumpSuccess")
    public String jumpSuccess(){
        return "success";
    }
	//跳转到登陆页面
    @RequestMapping("/login")
    public String login(String username, String pwd, HttpSession session, Model model){

    System.out.println("接收前端==="+username);

    session.setAttribute("user",username);
    model.addAttribute("user",username);
    return"success";
    }

	//注销用户
    @RequestMapping("/logout")
    public String lgoout(String username, String pwd, HttpSession session){

        session.removeAttribute("user");
        return"login";
    }


}
3、编写登陆成功的页面 success.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
   <title>Title</title>
</head>
<body>

<h1>登录成功页面</h1>
<hr>

${user}
<a href="${pageContext.request.contextPath}/user/logout">注销</a>
</body>
</html>
4、编写index.jsp页面
  • 这里使用请求controller访问WEB-INF下的页面
  • WEB-INF下的页面只能通过请求和serlvet访问
  • WEB-INF下的页面不能通过重定向访问
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>$Title$</title>
  </head>
  <body>
  <a href="${pageContext.request.contextPath}/user/jumplogin">登录</a>
  <a href="${pageContext.request.contextPath}/user/jumpSuccess">成功页面</a>
  </body>
</html>
5、编写用户登录拦截器
  • 放行了所有带login的请求
  • 放行了session中有user的请求
  • 使其它请求转发到login页面
package com.kuang.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class LoginInterceptor implements HandlerInterceptor {
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        if(request.getRequestURI().contains("login")){
            return true;
        }

        HttpSession session = request.getSession();
        if (session.getAttribute("user")!=null){
            return true;
        }
        request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request,response);
        return false;
    }
}
6、在Springmvc的配置文件中注册拦截器
		<mvc:interceptor>
            <mvc:mapping path="/user/**"/>
           <bean class="com.kuang.interceptor.LoginInterceptor"/>
        </mvc:interceptor>

运行展示

1、主页
在这里插入图片描述
2、点成功页面跳转到登陆页面
在这里插入图片描述
3、提交后跳转到成功页面
在这里插入图片描述
4、回到http://localhost:8090点击成功页面跳转成功
5、注销后回到登陆页面

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值