1. 程式人生 > 程式設計 >spring boot配置攔截器程式碼例項

spring boot配置攔截器程式碼例項

這篇文章主要介紹了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
@Component
public class ApiAccessInterceptor extends HandlerInterceptorAdapter {

@Autowired
private 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
**/
@Override
public 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,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
*/
@Configuration
public class WebConfig implements WebMvcConfigurer {

@Autowired
private ApiAccessInterceptor apiAccessInterceptor;
@Autowired
private CommProp commProp;

/**
* 攔截器配置
*
* @param registry 攔截器註冊類
* @return void
* @author Zxz
* @date 2019/10/25 17:53
**/
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/" + commProp.getPlayApiVersionLatest() + "/**");

//注意,攔截器配置不能使用配置檔案的統一api路徑配置:server.servlet.context-path,這樣配置是無效的。
//只能使用controller裡面的具體路徑配置,才能有效攔截
// registry.addInterceptor(apiAccessInterceptor).addPathPatterns("/play/api/**");

}
}
複製程式碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。