中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

springboot使用filter獲取自定義請求頭的實現代碼

發布時間:2020-08-26 12:45:03 來源:腳本之家 閱讀:210 作者:你都如何回憶我 欄目:編程語言

有個錢包項目,本來用的是微服務這一套,后來感覺沒必要,重構成了簡單的springboot項目,但是token校驗重構完之后出問題了,之前寫filter走的是springgateway,基于GatewayFilter實現,重構了之后基于filter,然后當請求進入過濾器的時候,發現不能獲取到請求的自定義請求頭。

String token = request.getHeader("token"); // null
String id = request.getHeader("id"); // null
String role = request.getHeader("role"); // null

原因

我在進入斷點的時候查看了一下servletRequest,發現請求方法是options。 我知道get post delete put。還真不了解options,百度了下。主要參考這篇文章。原來是瀏覽器的同源策略問題,也就是cors,可我一想,我配置了cors啊

@Configuration
public class CorsConfig {
  private CorsConfiguration buildConfig() {
    CorsConfiguration corsConfiguration = new CorsConfiguration();
    corsConfiguration.addAllowedOrigin("*"); // 1
    corsConfiguration.addAllowedHeader("*"); // 2
    corsConfiguration.addAllowedMethod("*"); // 3
    return corsConfiguration;
  }

  @Bean
  public CorsFilter corsFilter() {
    UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
    source.registerCorsConfiguration("/**", buildConfig()); // 4
    return new CorsFilter(source);
  }
}

怎么還報跨域的問題呢,想起來了我的tokenFilter里因為拿不到請求頭token,我拋出了參數異常,然后@RestControllerAdvice跟@ExceptionHandle處理不了filter中拋出的異常,導致程序報500錯誤,然后過濾器是類似于切面的 么,這里斷了導致返回頭也沒加上。

處理

怎么處理瀏覽器發過來的預處理 options請求呢,太懶了,直接這樣寫了

HttpServletRequest request= (HttpServletRequest)servletRequest;
    HttpServletResponse res = (HttpServletResponse) servletResponse;
    String method=request.getMethod();
    if(HttpMethod.OPTIONS.toString().equals(method)){
      res.setStatus(HttpStatus.NO_CONTENT.value());
    }else {
      String token = request.getHeader("token");
      String id = request.getHeader("id");
      String role = request.getHeader("role");
      ~~~~~~~

回想

我記得我上個項目也沒處理options請求啊,怎么沒報cors問題啊,對了我記得我在nginx處理過了

if ($request_method = 'OPTIONS') {
 return 204;
}
add_header Access-Control-Allow-Origin * always;
add_header Access-Control-Allow-Headers "Content-Type, Authorization" always;
add_header Access-Control-Allow-Methods "GET, POST, OPTIONS, PUT, PATCH, DELETE, HEAD" always;
add_header Access-Control-Max-Age 86400 always;

原來自己又寫前端,也寫后端,怎么這些問題還能碰到呢,:relieved:,前輩們都寫好了,自己還沒遇到問題也沒深入過,還有springcloud里面的corsWebFilter怎么就跟springboot里面的corsFilter不一樣呢。

@Configuration
public class CorsConfig {
  @Bean
  public CorsWebFilter corsFilter() {
    CorsConfiguration config = new CorsConfiguration();
    config.addAllowedMethod("*");
    config.addAllowedOrigin("*");
    config.addAllowedHeader("*");

    UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource(new PathPatternParser());
    source.registerCorsConfiguration("/**", config);

    return new CorsWebFilter(source);
  }
}

還是得多看源碼啊,我這個crudboy

總結

以上所述是小編給大家介紹的springboot使用filter獲取自定義請求頭的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桂东县| 泰州市| 东海县| 水富县| 庄河市| 信宜市| 阳新县| 富锦市| 太保市| 罗定市| 扬州市| 晋中市| 曲靖市| 黄山市| 广西| 湛江市| 迁西县| 北辰区| 虞城县| 称多县| 绩溪县| 英德市| 阿瓦提县| 垦利县| 大理市| 灵寿县| 交城县| 东山县| 芦溪县| 仙游县| 桃源县| 张北县| 恭城| 五华县| 禹州市| 永安市| 长春市| 石嘴山市| 长白| 晋宁县| 土默特右旗|