Spring Boot登录验证 拦截器HandlerInterceptor的使用

一般我们的都会用到登录验证,原理是:
登录成功后,服务端的session中会存在一个cookie,一般叫做JSESSIONID。
而有些请求需要登录状态才能操作,当请求比较多的时候,如果在每个controller里面获取session中的cookie然后再判断,会多次写重复代码先得非常冗余,特别是项目比较大的时候。这就不是我们想看到了,于是我们采用拦截器这种方式来处理登录验证。

登录验证的实现方式有两种:一、拦截器HandlerInterceptor 二、Spring AOP

方法一是在http请求层面的,相对简单,功能没有那么强大。
方法二则是spring的AOP特性,具体到某个类,十分强大,相对麻烦一点。

我主要介绍HandlerInterceptor的使用:
大概分为以下几步:
一、创建Interceptor并实现HandlerInterceptor接口;
二、创建配置类实现WebMvcConfigurer,并设置拦截路径

一、创建Interceptor并实现HandlerInterceptor接口;
package cn.swpu.mall.interceptor;

import cn.swpu.mall.consts.MallConst;
import cn.swpu.mall.exception.UserLoginException;
import cn.swpu.mall.pojo.User;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.servlet.HandlerInterceptor;

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

/**
 * @Date 2020/11/30 19:08
 */
@Slf4j
public class UserLoginInterceptor  implements HandlerInterceptor {

    /**
     * true 表示流程继续 false 表示中断
     * @param request
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        log.info("preHandle --->");

        User user = (User) request.getSession().getAttribute(MallConst.CURRENT_USER);
        if (user == null) {

            // 返回数据的两种方式: 不推荐,只能返回string,需要再次序列化 response.getWriter().println("error") 新建异常:
		    //这里是我通过抛出异常的方法,来返回json
            throw new UserLoginException();
        }
        return true;
    }
}
二、创建配置类实现WebMvcConfigurer,并设置拦截路径
package cn.swpu.mall.interceptor;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * @Author 冰翔
 * @Date 2020/11/30 19:23
 */
@Configuration
public class InterceptorConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        registry.addInterceptor(new UserLoginInterceptor())
        		//设置拦截路径,我是全部拦截,根据自己项目配置
                .addPathPatterns("/**") 
                //设置不拦截的路径
                //登录不用拦截,把登录拦截了,登录都需要已经登录的cookie这不就逻辑冲突了,注册也一样
                .excludePathPatterns("/user/login", "/user/register");
    }
}

需要注意配置和注解,以及实现的包路径。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以为您介绍如何使用Spring Boot拦截器实现登录功能。 首先,您需要编写一个拦截器类,该类实现Spring框架的HandlerInterceptor接口。在该类中,您可以编写拦截器逻辑来验证用户是否已经登录。以下是一个简单的示例: ```java @Component public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { HttpSession session = request.getSession(); Object user = session.getAttribute("user"); if (user == null) { response.sendRedirect("/login"); return false; } return true; } } ``` 在上面的代码中,我们检查了当前请求是否有一个名为“user”的session属性,如果没有,我们将用户重定向到登录页面并返回false。否则,我们允许请求通过并返回true。 接下来,您需要在您的Spring Boot应用程序中注册这个拦截器。您可以在应用程序的配置类中添加一个addInterceptors()方法,在该方法中注册您的拦截器。以下是一个示例: ```java @Configuration public class AppConfig implements WebMvcConfigurer { @Autowired private LoginInterceptor loginInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(loginInterceptor) .addPathPatterns("/**") .excludePathPatterns("/login", "/register"); // 不拦截登录和注册页面 } } ``` 在上面的代码中,我们将LoginInterceptor添加到拦截器注册表中,并指定拦截所有请求。我们还将/login和/register排除在拦截器之外,因为这些请求是用于登录和注册的,我们不想拦截它们。 最后,您需要在登录页面中编写一个表单,该表单将用户输入的用户名和密码发送到后端验证。如果验证成功,您可以将用户信息存储在session中,并重定向到您的应用程序首页。以下是一个示例: ```html <form method="post" action="/login"> <div> <label for="username">Username:</label> <input type="text" id="username" name="username"> </div> <div> <label for="password">Password:</label> <input type="password" id="password" name="password"> </div> <button type="submit">Login</button> </form> ``` 在上面的代码中,我们使用POST方法将用户名和密码发送到/login路由。在后端,您可以编写一个控制器方法来处理这个请求,并在验证成功后将用户信息存储在session中。 这就是使用Spring Boot拦截器实现登录功能的基本步骤。希望能对您有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值