spring boot配置拦截器代码实例
这篇文章主要介绍了springboot配置拦截器代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
首先引入web模块的依赖:
复制代码
复制代码
然后编写拦截器类:
复制代码
importlombok.extern.slf4j.Slf4j;
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.stereotype.Component;
importorg.springframework.util.StringUtils;
importorg.springframework.web.method.HandlerMethod;
importorg.springframework.web.servlet.handler.HandlerInterceptorAdapter;
importsimple.proj.zxz.play.comm.GeneralConsts;
importsimple.proj.zxz.play.pojo.vo.comm.CommOutVO;
importsimple.proj.zxz.play.prop.CommProp;
importsimple.proj.zxz.play.utils.JsonUtil;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
/**
*api访问拦截器
*
*@authorZxz
*@version1.0
*@dateCreatedat2018/11/24
**/
@Slf4j
@Component
publicclassApiAccessInterceptorextendsHandlerInterceptorAdapter{
@Autowired
privateCommPropcommProp;
/**
*http响应类型字段
*/
privatestaticfinalStringRESPONSE_CONTENT_TYPE="Content-Type";
/**
*http响应类型:json
*/
privatestaticfinalStringRESPONSE_HEADER_JSON="application/json";
/**
*访问认证拦截
*
*@paramrequest请求
*@paramresponse响应
*@paramhandler数据
*@returnboolean
*@authorZxz
*@date2019/10/2517:34
**/
@Override
publicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler)throwsException{
//方法类型过滤
if(!(handlerinstanceofHandlerMethod)){
returnsuper.preHandle(request,response,handler);
}
//token验证
Stringtoken=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()));
returnfalse;
}elseif(!auth(token)){
returnfalse;
}
returnsuper.preHandle(request,response,handler);
}
/**
*验证认证信息是否可以
*
*@paramtokentoken串
*@returnboolean
*@authorZxz
*@date2019/10/2517:48
**/
privatebooleanauth(Stringtoken){
returntoken.equals(commProp.getUserPermanentAuthorization());
}
}
复制代码
最后在配置类里面加入拦截器以及要拦截的路径:
复制代码
importcom.alibaba.fastjson.serializer.SerializerFeature;
importcom.alibaba.fastjson.support.config.FastJsonConfig;
importcom.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter4;
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.beans.factory.annotation.Qualifier;
importorg.springframework.boot.autoconfigure.http.HttpMessageConverters;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
importorg.springframework.web.servlet.config.annotation.InterceptorRegistry;
importorg.springframework.web.servlet.config.annotation.WebMvcConfigurer;
importsimple.proj.zxz.play.interceptors.ApiAccessInterceptor;
importsimple.proj.zxz.play.prop.CommProp;
/**
*web配置
*
*@authorzhangxz
*2019/10/25
*/
@Configuration
publicclassWebConfigimplementsWebMvcConfigurer{
@Autowired
privateApiAccessInterceptorapiAccessInterceptor;
@Autowired
privateCommPropcommProp;
/**
*拦截器配置
*
*@paramregistry拦截器注册类
*@returnvoid
*@authorZxz
*@date2019/10/2517:53
**/
@Override
publicvoidaddInterceptors(InterceptorRegistryregistry){
registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/"+commProp.getPlayApiVersionLatest()+"/**");
//注意,拦截器配置不能使用配置文件的统一api路径配置:server.servlet.context-path,这样配置是无效的。
//只能使用controller里面的具体路径配置,才能有效拦截
//registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/play/api/**");
}
}
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。