现在的位置: 首页 > 编程语言 > 正文

springboot配置拦截器代码实例

2020年02月13日 编程语言 ⁄ 共 3558字 ⁄ 字号 评论关闭

这篇文章主要介绍了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;

/*** api访问拦截器** @author Zxz* @version 1.0* @date Created at 2018/11/24**/

@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";

/*** 访问认证拦截** @param request 请求* @param response 响应* @param handler 数据* @return boolean* @author Zxz* @date 2019/10/25 17:34**/@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);}

/*** 验证认证信息是否可以** @param token token串* @return boolean* @author Zxz* @date 2019/10/25 17:48**/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;

/*** web配置** @author zhangxz* 2019/10/25*/@Configurationpublic class WebConfig implements WebMvcConfigurer {

@Autowiredprivate ApiAccessInterceptor apiAccessInterceptor;@Autowiredprivate CommProp commProp;

/*** 拦截器配置** @param registry 拦截器注册类* @return void* @author Zxz* @date 2019/10/25 17:53**/@Overridepublic void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/" + commProp.getPlayApiVersionLatest() + "/**");

//注意,拦截器配置不能使用配置文件的统一api路径配置:server.servlet.context-path,这样配置是无效的。//只能使用controller里面的具体路径配置,才能有效拦截// registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/play/api/**");

}}复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: spring boot配置拦截器代码实例

以上就上有关springboot配置拦截器代码实例的全部内容,学步园全面介绍编程技术、操作系统、数据库、web前端技术等内容。

抱歉!评论已关闭.