这篇文章给大家介绍如何在spring boot中配置拦截器,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
首先引入web模块的依赖:
<!-- spring boot web 组件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- spring boot web 组件 -->
然后编写拦截器类:
import lombok.extern.slf4j.Slf4j;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Component;import org.springframework.util.StringUtils;import org.springframework.web.method.HandlerMethod;import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;import simple.proj.zxz.play.comm.GeneralConsts;import simple.proj.zxz.play.pojo.vo.comm.CommOutVO;import simple.proj.zxz.play.prop.CommProp;import simple.proj.zxz.play.utils.JsonUtil; import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse; @Slf4j@Componentpublic class ApiAccessInterceptor extends HandlerInterceptorAdapter { @Autowiredprivate CommProp commProp; /*** http响应类型字段*/private static final String RESPONSE_CONTENT_TYPE = "Content-Type";/*** http响应类型:json*/private static final String RESPONSE_HEADER_JSON = "application/json"; @Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//方法类型过滤if (!(handler instanceof HandlerMethod)) {return super.preHandle(request, response, handler);} //token验证String token = request.getHeader(GeneralConsts.REQ_HEADER_AUTH);if (StringUtils.isEmpty(token)) {//没有token信息,未登录response.setHeader(RESPONSE_CONTENT_TYPE, RESPONSE_HEADER_JSON);response.getWriter().write(JsonUtil.toFormattedJsonString(CommOutVO.getNotAuth()));return false;} else if (!auth(token)) {return false;} return super.preHandle(request, response, handler);} private boolean auth(String token) {return token.equals(commProp.getUserPermanentAuthorization());} }
最后在配置类里面加入拦截器以及要拦截的路径:
import com.alibaba.fastjson.serializer.SerializerFeature;import com.alibaba.fastjson.support.config.FastJsonConfig;import com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter4;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.boot.autoconfigure.http.HttpMessageConverters;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.InterceptorRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;import simple.proj.zxz.play.interceptors.ApiAccessInterceptor;import simple.proj.zxz.play.prop.CommProp; @Configurationpublic class WebConfig implements WebMvcConfigurer { @Autowiredprivate ApiAccessInterceptor apiAccessInterceptor;@Autowiredprivate CommProp commProp; @Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/" + commProp.getPlayApiVersionLatest() + "/**"); //注意,拦截器配置不能使用配置文件的统一api路径配置:server.servlet.context-path,这样配置是无效的。//只能使用controller里面的具体路径配置,才能有效拦截// registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/play/api/**"); }}
springboot一种全新的编程规范,其设计目的是用来简化新Spring应用的初始搭建以及开发过程,SpringBoot也是一个服务于框架的框架,服务范围是简化配置文件。
关于如何在spring boot中配置拦截器就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。