精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

五種方案!保護(hù)Spring Boot API接口安全

開發(fā) 前端
Filter 是 Java Servlet 規(guī)范中的一個組件,可以在請求到達(dá) Servlet 之前或響應(yīng)返回客戶端之前對請求和響應(yīng)進(jìn)行攔截和處理。通過在 Filter 中實(shí)現(xiàn)權(quán)限認(rèn)證邏輯,可以有效地控制用戶對 API 接口的訪問權(quán)限。

環(huán)境:SpringBoot3.4.2

1. 簡介

API是系統(tǒng)核心數(shù)據(jù)的出入口,必須防止未授權(quán)訪問、數(shù)據(jù)泄露、惡意攻擊等風(fēng)險。例如:

  • 防止游客查看敏感數(shù)據(jù)(如用戶信息)
  • 阻止越權(quán)操作(如普通用戶刪除管理員數(shù)據(jù))
  • 抵御惡意刷接口或注入攻擊

合理的權(quán)限控制能確保數(shù)據(jù)安全、系統(tǒng)穩(wěn)定,并符合合規(guī)要求。

接下來我將詳細(xì)的介紹 5 種簡單好用的保護(hù)方案,讓你能輕松搞定 API 接口安全。

以下是本篇文章要實(shí)現(xiàn)的5種方案:

  • 通過Filter實(shí)現(xiàn)
  • 使用Interceptor攔截器實(shí)現(xiàn)
  • 基于AOP+Filter實(shí)現(xiàn)
  • 使用Spring Security實(shí)現(xiàn)
  • 整合OAuth2認(rèn)證

2.實(shí)戰(zhàn)案例

準(zhǔn)備如下Controller接口

@RestController
public class ApiController {
  @GetMapping("/api/query")
  public ResponseEntity<?> query() {
    System.err.println(SecurityContext.get()) ;
    return ResponseEntity.ok("query...") ;
  }


  @GetMapping("/create")
  public ResponseEntity<?> create() {
    return ResponseEntity.ok("create...") ;
  }
}

這里提供了2個接口。其中,/api/query是需要認(rèn)證的接口,/create無需認(rèn)證,可直接訪問。

2.1 通過Filter實(shí)現(xiàn)

Filter 是 Java Servlet 規(guī)范中的一個組件,可以在請求到達(dá) Servlet 之前或響應(yīng)返回客戶端之前對請求和響應(yīng)進(jìn)行攔截和處理。通過在 Filter 中實(shí)現(xiàn)權(quán)限認(rèn)證邏輯,可以有效地控制用戶對 API 接口的訪問權(quán)限。

代碼實(shí)現(xiàn):

@WebFilter("/api/*")
public class JwtAuthFilter implements Filter {
  @Override
  public void doFilter(ServletRequest req, ServletResponse resp, FilterChain filterChain)
      throws IOException, ServletException {
    HttpServletRequest request = (HttpServletRequest) req ;
    HttpServletResponse response = (HttpServletResponse) resp ;
    try {
      // 從請求header中讀取token
      String token = JwtUtil.extractToken(request) ;
      // 驗(yàn)證token & 將從token中解析出的數(shù)據(jù)保存到線程上下文中
      if (token != null && JwtUtil.validateToken(token)) {
        Map<String, Object> data = JwtUtil.parseToken(token) ;
        SecurityContext.set(data) ;
        filterChain.doFilter(request, resp) ;
      } else {
        // 認(rèn)證失敗,則直接輸出錯誤內(nèi)容
        response.setContentType("application/json;charset=utf-8");
        response.getWriter().println(new ObjectMapper()
            .writeValueAsString(Map.of("code", -1, "msg", "無效token"))) ;
        return ;
      }
    } finally {
      SecurityContext.clear() ;
    }
  }
}

此過濾器將只攔截 /api 開頭的請求。

運(yùn)行結(jié)果

圖片圖片

圖片圖片

提供正確的token再次訪問

圖片圖片

2.2 使用Interceptor攔截器

HandlerInterceptor 是 Spring MVC 提供的一個接口,可以在請求處理前后進(jìn)行攔截。通過實(shí)現(xiàn)其 preHandle 方法,可以在請求到達(dá)控制器之前進(jìn)行權(quán)限驗(yàn)證,決定是否允許請求繼續(xù)執(zhí)行。

代碼實(shí)現(xiàn):

@Component
public class AuthInterceptor implements HandlerInterceptor {
  private final ObjectMapper objectMapper ;
  public AuthInterceptor(ObjectMapper objectMapper) {
    this.objectMapper = objectMapper ;
  }
  @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    String token = JwtUtil.extractToken(request) ;
    if (token != null && JwtUtil.validateToken(token)) {
      Map<String, Object> data = JwtUtil.parseToken(token) ;
      SecurityContext.set(data) ;
      return true ;
    } else {
      response.setContentType("application/json;charset=utf-8");
      response.getWriter().println(objectMapper
          .writeValueAsString(Map.of("code", -1, "msg", "無效token"))) ;
      return false ;
    }
  }
  @Override
  public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
      throws Exception {
    SecurityContext.clear() ;
  }
}

注冊攔截器

@Component
public class WebConfig implements WebMvcConfigurer {
  private final AuthInterceptor authInterceptor ;
  public WebConfig(AuthInterceptor authInterceptor) {
    this.authInterceptor = authInterceptor;
  }
  @Override
  public void addInterceptors(InterceptorRegistry registry) {
    registry.addInterceptor(this.authInterceptor).addPathPatterns("/api/**") ;
  }
}

注意:不要忘記在攔截器的 afterCompletion 中進(jìn)行上下文的清理。

2.3 使用AOP + Filter實(shí)現(xiàn)

AOP用于定義權(quán)限驗(yàn)證的切面邏輯,F(xiàn)ilter 則用于攔截請求并解析處理Token。這種組合方式能夠在請求處理的不同階段進(jìn)行權(quán)限控制,既靈活又高效,適合在需要復(fù)雜權(quán)限管理。

代碼實(shí)現(xiàn):

Filter實(shí)現(xiàn)

@WebFilter("/*")
public class TokenFilter implements Filter {
  @Override
  public void doFilter(ServletRequest req, ServletResponse resp, FilterChain filterChain)
      throws IOException, ServletException {
    HttpServletRequest request = (HttpServletRequest) req ;
    try {
      String token = JwtUtil.extractToken(request) ;
      if (token != null && JwtUtil.validateToken(token)) {
        Map<String, Object> data = JwtUtil.parseToken(token) ;
        SecurityContext.set(data) ;
      }
      filterChain.doFilter(request, resp) ;
    } finally {
      SecurityContext.clear() ;
    }
  }
}

AOP切面實(shí)現(xiàn)

// 自定義注解
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface PermissionCheck {


  String[] value() default {} ;
}
// 切面定義
@Aspect
@Component
public class PermissionAspect {
  @SuppressWarnings("unchecked")
  @Around("@annotation(permissionCheck)")
  public Object checkPermission(ProceedingJoinPoint joinPoint, PermissionCheck permissionCheck) throws Throwable {
    try {
      Map<String, Object> data = SecurityContext.get() ;
      if (data == null) {
        throw new PermissionException("無權(quán)限訪問", 403) ;
      }
      // 獲取所需角色
      String[] requiredRoles = permissionCheck.value() ;
      // 用戶所擁有的角色
      List<String> assignedRoles = (List<String>) data.get("roles") ; 
      // 判斷2個集合如果沒有共同元素則返回true
      if (Collections.disjoint(List.of(requiredRoles), assignedRoles)) {
        throw new PermissionException("無權(quán)限訪問", 403) ;
      }
      // 繼續(xù)執(zhí)行方法
      return joinPoint.proceed();
    } catch (Exception e) {
      e.printStackTrace() ; 
      throw new PermissionException("Token無效或過期", 401) ;
    }
  }
}

修改Controller接口

@GetMapping("/api/query")
@PermissionCheck({"api:query"})
public ResponseEntity<?> query() {
  return ResponseEntity.ok("query...") ;
}

2.4 使用Spring Security

Spring Security 是 Spring 生態(tài)中的安全框架,提供了豐富的權(quán)限控制功能,包括身份認(rèn)證、授權(quán)、密碼加密等。通過配置安全規(guī)則和過濾器鏈,可以輕松實(shí)現(xiàn)細(xì)粒度的權(quán)限控制。

代碼實(shí)現(xiàn):

首先,引入依賴

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-security</artifactId>
</dependency>

最后,安全配置

@Configuration
public class SecurityConfig {
  @Bean
  SecurityFilterChain apiSecurity(HttpSecurity http) throws Throwable {
    http.csrf(csrf -> csrf.disable()) ;
    http.securityMatcher("/api/**", "/login") ;
    http.formLogin(Customizer.withDefaults()) ;
    http.authorizeHttpRequests(registry -> {
      registry.anyRequest().authenticated() ;
    }) ;
    return http.build() ;
  }
  // 實(shí)際我們應(yīng)該從數(shù)據(jù)庫中查詢,這里為了簡單直接固定一個內(nèi)存用戶
  @Bean
  UserDetailsService userDetailsService() {
    UserDetails user = User.withUsername("pack")
      .password("{noop}123123")
      .roles("ADMIN")
      .build() ;
    return new InMemoryUserDetailsManager(user) ;
  }
}

在上面的SecurityFilterChain配置中,我們將只會對/api/*,/login接口進(jìn)行攔截。如果沒有權(quán)限將會自動定向到登錄頁面。

當(dāng)訪問/api/query接口時,自動跳轉(zhuǎn)到登錄頁面:

圖片圖片

輸入正確的用戶名密碼后,自動跳回之前的接口地址

圖片圖片

責(zé)任編輯:武曉燕 來源: Springboot全家桶實(shí)戰(zhàn)案例源碼
相關(guān)推薦

2025-02-12 08:47:07

SpringAPI接口

2025-02-13 07:45:26

APISpringHTTP

2024-08-29 09:01:39

2025-06-30 01:45:00

2025-07-11 01:45:00

API監(jiān)控Spring

2025-08-28 07:48:33

2021-09-18 10:06:06

數(shù)據(jù)安全隱私計算大數(shù)據(jù)

2025-03-31 08:39:55

2023-10-16 11:12:29

2024-03-14 12:00:52

2025-04-30 08:39:33

SpringMVC接口

2025-05-14 04:00:00

2022-07-04 07:41:53

接口數(shù)據(jù)安全

2025-06-09 01:22:00

2023-05-17 13:46:14

2024-09-29 09:31:08

Spring前綴URL

2024-09-26 08:03:37

2025-03-12 02:00:55

API接口優(yōu)化

2025-08-08 01:55:00

SpringJSON日期

2025-06-12 02:00:00

Spring簽到打卡
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

精品久久在线| 黑人与亚洲人色ⅹvideos| 欧美婷婷在线| 日韩www在线| 亚洲不卡视频在线| 成人在线app| 成人美女视频在线看| 日本最新高清不卡中文字幕| 三级黄色片在线观看| 一区二区三区免费在线看| 粉嫩老牛aⅴ一区二区三区| 亚洲欧洲一区二区| 亚洲国产精品suv| 久久综合亚州| 久久福利网址导航| 国产人妻一区二区| 国产精品2区| 一本一道波多野结衣一区二区| 做爰高潮hd色即是空| 亚洲 精品 综合 精品 自拍| 国内精品写真在线观看| 热门国产精品亚洲第一区在线| 日本一级二级视频| 国产欧美久久一区二区三区| 日韩欧美一二区| 天天操,天天操| 亚洲精品日产| 亚洲黄色免费网站| 亚洲午夜精品福利| 免费在线一级视频| 成人av电影免费观看| 国产在线一区二区三区| 麻豆成人免费视频| 亚洲日韩视频| 色综合视频网站| 在线视频这里只有精品| 国产精品亚洲人成在99www| 亚洲国产欧美一区二区丝袜黑人 | 日韩精品无码一区二区| 91精品精品| 日韩视频中文字幕| 亚洲第一综合网| 中文字幕精品影院| 日韩精品在线私人| 三级男人添奶爽爽爽视频| 日韩在线网址| 欧美一级xxx| 亚洲精品成人在线播放| 日韩护士脚交太爽了| 欧美午夜一区二区| 日本男人操女人| se01亚洲视频| 欧美性生活影院| 成年人免费在线播放| 亚洲十八**毛片| 欧美午夜精品在线| 欧美成人黑人猛交| 网友自拍亚洲| 欧美综合在线视频| 天天干天天综合| 日韩伦理一区二区| 欧美高清视频一二三区| 中文字幕第22页| 欧美电影在线观看一区| 欧美一级二级三级蜜桃| 日批视频免费看| 麻豆成人入口| 日韩av在线免费观看一区| www.久久国产| 国产一区二区三区四区大秀| 自拍偷拍亚洲在线| 久久国产精品国语对白| 国产综合婷婷| 91国产美女视频| 精品人妻一区二区三区潮喷在线 | 激情小说欧美色图| 成人高潮a毛片免费观看网站| 亚洲国产精品人人爽夜夜爽| 国产艳俗歌舞表演hd| 精品国产日韩欧美| 久久影院资源网| 国产一级做a爱免费视频| 亚洲免费中文| 国产精品视频久久| 性欧美8khd高清极品| 99re8在线精品视频免费播放| 女女同性女同一区二区三区91| www 日韩| 亚洲va中文字幕| 亚洲成人福利在线观看| 嫩呦国产一区二区三区av| 日韩经典一区二区三区| 日本黄区免费视频观看| 国产综合欧美| 国产剧情久久久久久| 亚洲精品久久久久久久久久久久久久 | 亚洲欧美另类久久久精品| 日本人体一区二区| 99riav视频一区二区| 日韩精品一区二区三区swag| 亚洲狠狠婷婷综合久久久久图片| 日韩久久视频| 午夜精品久久久久久久99黑人| 久操视频在线免费观看| 国产成人欧美日韩在线电影| 牛人盗摄一区二区三区视频| 在线黄色网页| 欧日韩精品视频| 国产女人18毛片水真多18| 久久美女视频| 欧美中文字幕第一页| 国产亲伦免费视频播放| 久久久99精品久久| 天堂8在线天堂资源bt| 78精品国产综合久久香蕉| 亚洲国产高清高潮精品美女| 中国一级片在线观看| 久久动漫亚洲| 国产一区福利视频| 宅男网站在线免费观看| 欧美日韩一区二区在线观看| 亚洲国产无码精品| 伊人久久久大香线蕉综合直播| 国产欧美一区二区三区在线看| 亚洲日本在线播放| 亚洲午夜久久久久| 三级黄色片免费观看| 欧美精品一二| 欧美孕妇毛茸茸xxxx| 亚洲国产综合一区| 亚洲欧美激情小说另类| xxx国产在线观看| 一区二区三区视频免费观看| 国模gogo一区二区大胆私拍| av中文字幕免费在线观看| 国产日韩欧美精品在线| 欧美v在线观看| 欧美日日夜夜| 午夜精品久久久久久99热软件| 亚洲av无码乱码国产精品| 亚洲免费在线观看视频| 一区二区三区四区毛片| 久久视频国产| 91精品免费久久久久久久久| 91短视频版在线观看www免费| 91国在线观看| 免费看黄色三级| 久久精品日产第一区二区| 欧美精品成人一区二区在线观看| 麻豆mv在线观看| 亚洲精品国产电影| 色婷婷av国产精品| 久久亚洲一区二区三区明星换脸| 亚洲美免无码中文字幕在线| 欧美理论电影在线精品| 欧美一级视频在线观看| 日本亚洲一区| 91久久奴性调教| 人人妻人人藻人人爽欧美一区| 亚洲一区亚洲| 热re99久久精品国99热蜜月| 国模视频一区| 综合欧美国产视频二区| 国产精品毛片一区二区在线看舒淇| 国产精品大尺度| 亚洲综合在线一区二区| 国产综合精品一区| 蜜桃网站成人| 亚洲精品555| 久久av资源网站| 粉嫩av一区二区夜夜嗨| 偷窥国产亚洲免费视频 | 国产精品久久久久影院| 国内自拍第二页| 欧美 亚欧 日韩视频在线 | 欧美大尺度做爰床戏| 四季av一区二区凹凸精品| 91精品视频免费观看| 超黄网站在线观看| 日韩精品在线免费观看| 伊人网综合在线| 一个色妞综合视频在线观看| 日韩精品一区二区三区高清免费| 久久在线精品| 日本三日本三级少妇三级66| 国产精品传媒| 国产精品日韩在线| 羞羞的视频在线观看| 精品亚洲男同gayvideo网站| 在线免费看av的网站| 樱花影视一区二区| 美女洗澡无遮挡| 国产裸体歌舞团一区二区| 亚洲熟妇av日韩熟妇在线| 青青草97国产精品麻豆| 91视频免费进入| 美女福利一区二区| 欧美国产激情18| 国内在线免费高清视频| 日韩精品中文字幕在线不卡尤物| 国产剧情在线视频| 亚洲精品第1页| 中国女人特级毛片| 懂色av中文一区二区三区| 成人免费视频久久| 亚洲高清毛片| 国产成人精品免费看在线播放| 久久亚洲道色| 亚洲综合精品一区二区| 欧美羞羞视频| 欧美激情极品视频| 午夜在线视频| 亚洲欧美日韩久久久久久| 亚洲第一天堂网| 欧美日韩视频在线一区二区| 毛片视频网站在线观看| 一个色综合av| 亚洲一级生活片| 国产女同互慰高潮91漫画| 天堂久久久久久| 国产丶欧美丶日本不卡视频| 久久国产精品国产精品| 香蕉久久久久久久av网站| 黄色特一级视频| 999精品在线| 亚洲精品一卡二卡三卡四卡| 日韩在线你懂的| 成人av资源| 久久伊人久久| 91日韩在线播放| 欧美成人aaa| 国产精品欧美一区二区| 户外露出一区二区三区| 日本免费在线精品| 少妇视频在线观看| 午夜免费久久久久| jizz一区二区三区| 欧美激情视频网址| 国产嫩草在线视频| 欧美极品美女电影一区| 18在线观看的| 精品中文字幕在线2019| av在线free| 久久av.com| 在线看一级片| 久久久人成影片一区二区三区| 午夜av在线播放| 欧美理论电影在线观看| 羞羞视频在线观看免费| 久久久久久久电影一区| 久草在线新免费首页资源站| 欧美激情精品久久久久久蜜臀| 污视频免费在线观看| 欧美激情精品久久久久久黑人| 欧美78videosex性欧美| 久久青草福利网站| 国产直播在线| 日本久久久久久久久久久| 日韩pacopacomama| 国产免费久久av| 国产日韩在线观看视频| 91成人免费看| 国产一级成人av| 久久久99国产精品免费| 国产99精品| 亚洲精品免费在线看| 日韩中字在线| 国产欧美自拍视频| 日韩视频在线一区二区三区| 红桃av在线播放| 七七婷婷婷婷精品国产| 亚洲制服中文字幕| 成人午夜电影小说| 一级性生活毛片| 国产精品理伦片| 久久久久亚洲AV| 日韩欧美中文在线| 一区二区日韩在线观看| 日韩欧美国产精品| 黄色网址在线播放| x99av成人免费| a级大胆欧美人体大胆666| 日韩免费av在线| 精品午夜视频| 欧美日韩国产高清视频| 91青青国产在线观看精品| 日韩中文字幕在线免费| 日韩福利电影在线| 免费观看一区二区三区| 久久精品人人做| 一区二区视频免费看| 日韩欧美在线观看| av免费在线不卡| 亚洲最大在线视频| 日本三级在线观看网站| 国产精品久久久av| 在线一区二区三区视频| 欧美日韩亚洲综合一区二区三区激情在线| 99久久综合狠狠综合久久aⅴ| www.av毛片| 精品一区二区在线免费观看| 内射中出日韩无国产剧情| 中文字幕一区二区在线观看| 97免费在线观看视频| 欧美一区二区三区免费视频 | 伦伦影院午夜日韩欧美限制| 黄色在线免费观看网站| 亚洲一区二区三区四区视频| 久久成人高清| 免费网站在线观看视频| 男人的天堂亚洲一区| 久久久久亚洲AV成人无码国产| 国产精品久久久久一区| 久久久久女人精品毛片九一| 日韩欧美123| 在线观看黄av| 国产999精品视频| 国产精品传媒| 日韩欧美猛交xxxxx无码| 久久国产精品免费| 国产毛片久久久久久久| 婷婷六月综合网| 国产成人手机在线| 成年人精品视频| 性欧美video另类hd尤物| 欧美中日韩免费视频| 亚洲精品精选| 蜜桃色一区二区三区| 亚洲美腿欧美偷拍| 一炮成瘾1v1高h| 中文字幕亚洲一区二区三区五十路 | 欧美交a欧美精品喷水| 一本色道久久88亚洲精品综合| 免费在线成人网| 亚洲第一视频区| 91久久精品日日躁夜夜躁欧美| 视频国产在线观看| 91wwwcom在线观看| 美国一区二区| 国产资源在线视频| 成人h动漫精品一区二区| 久久久久久av无码免费网站| 欧美一级高清片| 久久香蕉av| 国产精品夜夜夜一区二区三区尤| 欧美私人啪啪vps| 在线中文字日产幕| 午夜视频在线观看一区二区| 欧美一级淫片aaaaaa| 欧美激情亚洲激情| 国语一区二区三区| 国产97在线 | 亚洲| 久久久久久久性| 一级久久久久久| 日韩中文字幕视频在线| 亚洲电影二区| 国产精品国产三级国产专区51| 国产精品主播直播| 国产成人啪精品午夜在线观看| 亚洲国产精品系列| 日韩成人动漫| 亚洲欧洲日韩综合二区| 国产精品456| 免费一级特黄特色大片| 亚洲精品视频免费在线观看| 色香欲www7777综合网| 亚洲一区二区不卡视频| 国产伦理精品不卡| 日韩无码精品一区二区三区| 亚洲精品自拍偷拍| 成人不卡视频| 性欧美18一19内谢| 成人中文字幕电影| 亚洲第一精品在线观看| 亚洲网址你懂得| 国产乱码精品一区二区三区亚洲人 | 免费福利在线视频| 国产精品日韩欧美| 国产精品99一区二区| 中文在线一区二区三区| 欧美日韩一区二区三区在线看| 在线播放免费av| 久久国产精品久久精品国产| 男女视频一区二区| 青青草国产在线观看| 亚洲精品一区二区网址| 色8久久久久| 无码人妻精品一区二区蜜桃网站| 91蜜桃视频在线| 91精东传媒理伦片在线观看| 久久久久久有精品国产| 国产一区二区三区电影在线观看| 色姑娘综合天天| 色噜噜久久综合| 三级资源在线| 视频一区视频二区视频三区视频四区国产 | 精品国产无码AV| 日韩69视频在线观看| 欧美精品啪啪| 91大神福利视频|