精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

色偷偷噜噜噜亚洲男人的天堂| 亚洲欧美日韩电影| 国产成人激情小视频| 午夜国产福利视频| 91蜜桃臀久久一区二区| 色婷婷精品久久二区二区蜜臂av| 91精品婷婷国产综合久久| 一本久道久久综合狠狠爱亚洲精品| a天堂视频在线| 久久久精品日韩| 久久精品国产久精国产一老狼| 久久久久久久久久久久国产精品| 色老太综合网| 亚洲综合色自拍一区| 欧美一区激情视频在线观看| www夜片内射视频日韩精品成人| 一区二区动漫| 九九热这里只有精品免费看| 91成年人网站| aaa国产精品| 欧美日韩精品久久久| 18禁免费观看网站| jizz性欧美| 久久久久久9999| 国产精品二区在线| 亚洲性生活大片| 校园春色综合网| 欧美激情视频在线观看| 五月天婷婷丁香网| 中文字幕中文字幕精品| 欧美成人国产一区二区| 午夜视频在线网站| 免费在线成人激情电影| 亚洲成人av在线电影| 亚洲免费av网| 五月香视频在线观看| 久久久久久久久久久99999| 国产区一区二区三区| 精品国自产在线观看| 久久99国产精品久久| 国产精品女视频| 日韩黄色片网站| 亚洲美女网站| 91精品国产91久久久久| 国产中文字字幕乱码无限| 中文字幕一区二区三区在线视频| 日韩在线视频国产| 萌白酱视频在线| 成人精品亚洲| 中文字幕久精品免费视频| 色婷婷在线影院| 羞羞答答一区二区| 精品视频一区在线视频| 亚州av综合色区无码一区| 国产精品va在线观看视色| 人妻少妇精品视频一区二区三区| 国产呦系列欧美呦日韩呦| 蜜桃免费一区二区三区| 狠狠人妻久久久久久综合| 日韩一区二区久久| 国模视频一区二区三区| 国产精品a成v人在线播放| 在线日韩中文| 97人洗澡人人免费公开视频碰碰碰| 久久久久久蜜桃| 亚洲国产第一| 欧洲亚洲免费在线| 中文字幕天堂在线| 激情图区综合网| 亚洲最大成人网色| 可以免费观看的毛片| 永久免费精品视频| 国产成人av电影免费在线观看| 国产日韩精品一区二区| 国产精品无码白浆高潮| 国产一区二区精品久久91| 999日本视频| 手机看片国产1024| 久久久久久夜精品精品免费| 日韩精品伦理第一区| 一区二区三区视频网站| 最新热久久免费视频| 黄色一级片av| 电影在线观看一区| 欧美怡红院视频| 午夜精品久久久久久久99热影院| 国产精品一区三区在线观看| 亚洲成人999| 午夜精产品一区二区在线观看的| 99精品视频在线观看播放| 欧美成人免费播放| youjizz在线视频| 久久99久久久欧美国产| 99视频网站| 国产专区在线播放| 亚洲色图都市小说| 久久无码高潮喷水| 大胆国模一区二区三区| 日韩电视剧在线观看免费网站| 成熟人妻av无码专区| 欧美在线网址| 欧美主播福利视频| 国产精品免费无遮挡| www.亚洲人| 亚洲综合首页| 九色porny丨入口在线| 欧美日韩国产免费一区二区| 女性生殖扒开酷刑vk| 精品久久精品| 国模私拍视频一区| 国产欧美日韩综合精品一区二区三区| 99视频在线精品| 一区二区在线不卡| 午夜不卡影院| 欧美大片一区二区三区| youjizz.com国产| 中文字幕乱码视频| 久久精品国产久精国产| 国产伦精品一区二区三毛| 亚洲麻豆精品| 色婷婷av一区二区三区之一色屋| 中文字幕人妻一区| 欧美国产91| 国产又爽又黄的激情精品视频| 婷婷丁香一区二区三区| 亚洲免费观看在线视频| 久久精品免费网站| 亚洲图片久久| 97视频在线观看视频免费视频| 国产精品特级毛片一区二区三区| 国产日韩欧美电影| 欧美 日韩 激情| 成人精品毛片| 欧美激情女人20p| a天堂中文在线观看| 亚洲欧美在线视频| 三上悠亚在线一区二区| re久久精品视频| 日韩美女中文字幕| 女人偷人在线视频| 欧美午夜精品久久久久久浪潮| 亚洲一区二区三区四区av| 中文字幕一区二区三三| 91中文在线观看| av软件在线观看| 欧美日韩精品免费| 三级全黄做爰视频| 国产一区日韩二区欧美三区| 天天成人综合网| 精品国产亚洲一区二区三区大结局| 日韩中文字幕不卡视频| 在线播放一级片| 国产精品全国免费观看高清| 中文字幕有码av| 成人在线视频免费观看| 国产精品久久久久久久久免费看| 久久99久久| 91国在线观看| 色噜噜噜噜噜噜| 久久精品噜噜噜成人av农村| 色噜噜狠狠一区二区三区| 国产精品videossex撒尿| 亚洲色图激情小说| 一区精品在线观看| 中文字幕综合网| 日本在线视频播放| 亚洲美女视频在线免费观看| 久久99精品久久久久久三级 | 最近2019年手机中文字幕| 夜夜躁日日躁狠狠久久av| 欧美国产日韩亚洲一区| 亚洲免费黄色录像| 欧美在线看片| 久久久水蜜桃| 激情中国色综合| 久久久99久久精品女同性| www.午夜激情| 精品毛片网大全| 丁香激情五月少妇| 国产精品自拍av| 狠狠干 狠狠操| 不卡一区综合视频| 91视频免费进入| 女人让男人操自己视频在线观看| 尤物九九久久国产精品的分类| 97精品人妻一区二区三区香蕉| 亚洲一区在线看| 免费黄色在线视频| 极品尤物av久久免费看| 国内少妇毛片视频| 欧美日韩一区二区综合| 亚洲一区二区三区777| 中文在线资源| 精品国产依人香蕉在线精品| 五月天婷婷视频| 精品视频在线免费| 日韩av在线播| 国产精品久久久久婷婷| 精品人妻一区二区免费| 青青草97国产精品免费观看| 免费看日b视频| 国产亚洲电影| 国产传媒一区二区三区| 精品视频在线一区二区在线| 欧美高清视频在线| 中文字幕在线视频区| 亚洲国内高清视频| 国产伦一区二区| 在线一区二区视频| 日韩免费一二三区| 综合在线观看色| 鲁丝一区二区三区| 成人性视频网站| 天堂av8在线| 久久天天综合| 极品美女扒开粉嫩小泬| 欧美~级网站不卡| 亚洲欧美在线网| 免费欧美激情| 精品国产免费久久久久久尖叫| av一级久久| 国产日韩在线亚洲字幕中文| 在线看的毛片| 久久久久久久亚洲精品| 快射视频在线观看| 揄拍成人国产精品视频| 亚洲欧美日本在线观看| 精品少妇一区二区| 国产偷人妻精品一区二区在线| 在线观看av一区二区| 女人十八岁毛片| 亚洲电影中文字幕在线观看| 岛国毛片在线观看| 亚洲欧美中日韩| 天天爽天天爽天天爽| 中文字幕免费不卡| 中文字幕 自拍| 久久久久久久综合| 欧洲女同同性吃奶| 91一区在线观看| 国产毛片毛片毛片毛片毛片毛片| 国产伦精品一区二区三区免费迷| 欧美成人福利在线观看| 免费看欧美女人艹b| 搡女人真爽免费午夜网站| 午夜亚洲精品| 无码精品国产一区二区三区免费| 国产精品人人爽人人做我的可爱| 国产伦精品一区二区三区四区视频_| 亚洲成人原创| 成人性免费视频| 中文国产一区| 国产肥臀一区二区福利视频| 99精品免费视频| 狠狠97人人婷婷五月| 中日韩视频在线观看| 亚洲色欲综合一区二区三区| 乱码第一页成人| 一区二区三区国产免费| 石原莉奈在线亚洲三区| 男人添女人下面免费视频| 久久成人羞羞网站| 性久久久久久久久久久久久久| 国产中文字幕精品| 国产精品19p| 不卡的av中国片| 国产精品揄拍100视频| 国产视频亚洲色图| 亚洲少妇xxx| 亚洲一卡二卡三卡四卡无卡久久| 日韩av在线播放观看| 日韩欧美一区视频| 最近中文字幕av| 91精品国产乱码| 亚洲成人一二三区| 亚洲精品二三区| av在线资源站| 九色精品美女在线| 少妇视频在线观看| 国产欧美一区二区白浆黑人| 国产美女精品视频免费播放软件| 国产精选在线观看91| 国产欧美一区二区精品久久久| 亚洲精品日韩成人| 欧美国产91| 玩弄japan白嫩少妇hd| 精品一区二区三区在线播放| 三上悠亚 电影| 国产欧美精品日韩区二区麻豆天美| 中文字幕资源站| 精品福利在线观看| 亚洲综合视频在线播放| 欧美精品一区二区蜜臀亚洲| 黄上黄在线观看| 欧美黄色www| 少妇精品视频一区二区免费看| 99久久99久久| 郴州新闻综合频道在线直播| 妞干网视频在线观看| 日本亚洲最大的色成网站www| 丰满少妇一区二区三区专区| www国产亚洲精品久久麻豆| 亚洲欧美精品aaaaaa片| 狠狠色狠狠色综合日日小说| 91成品人影院| 国产视频久久久| 色yeye免费人成网站在线观看| 日韩av男人的天堂| 中文久久电影小说| 伊甸园精品99久久久久久| 国产精品综合| 亚洲av午夜精品一区二区三区| 国产欧美日韩精品在线| 日韩av在线播| 日韩精品一区二| 国产乱色在线观看| 国产精品美女呻吟| 伊人久久大香线蕉无限次| 亚洲色婷婷久久精品av蜜桃| 日韩福利电影在线观看| 给我看免费高清在线观看| 亚洲理论在线观看| 91成品人影院| 色一情一乱一区二区| 欧美羞羞视频| 久久久久无码国产精品一区| 欧美午夜不卡| 熟妇无码乱子成人精品| 国产精品国产三级国产普通话99| 黑人精品无码一区二区三区AV| 亚洲国产小视频在线观看| 黄色污污视频在线观看| 99re6在线| 亚洲欧美一区在线| 日本中文字幕在线不卡| 18欧美亚洲精品| 91麻豆成人精品国产免费网站| 亚洲网址你懂得| 欧美片第1页| 色姑娘综合av| 免费看黄色91| 91免费在线看片| 欧美日韩亚洲高清一区二区| 91精品国产综合久久久久久豆腐| 国产精品盗摄久久久| 国产日产精品_国产精品毛片| 波多野结衣家庭教师视频 | 国产午夜福利一区| 色婷婷av一区二区三区大白胸 | 另类少妇人与禽zozz0性伦| 色999韩欧美国产综合俺来也| 婷婷五月色综合| 免费人成精品欧美精品| 波多野结衣欲乱| 欧美色精品在线视频| 97电影在线| 91久久国产精品91久久性色| 91超碰国产精品| 国产精品日日摸夜夜爽| 亚洲福利一区二区三区| 五月天婷婷视频| 国产精品美女www| 国产高清欧美| 亚洲AV成人精品| 午夜久久福利影院| 精品视频二区| 成人国产在线激情| 综合视频在线| 免费成人蒂法网站| 色成人在线视频| 日本成人在线播放| 91视频最新| 国产精品一级| 美女网站视频色| 欧美刺激脚交jootjob| 性爽视频在线| 亚洲一区二区免费视频软件合集 | 在线免费看a| av色综合网| 久久久久久黄| 在线观看美女av| 日韩av网站电影| 日韩三级一区| 日韩欧美不卡在线| 国产日产精品一区| www.国产免费| 国产suv精品一区二区三区88区| 日韩在线第七页| 久久久男人的天堂| 欧美色欧美亚洲另类二区| 免费男女羞羞的视频网站在线观看 | 国产a级黄色大片| 久久午夜老司机| 国产特级黄色片| 日本在线观看天堂男亚洲| 欧美大黑bbbbbbbbb在线| 国产精品一区二区在线免费观看| 一本色道综合亚洲| 色呦呦在线播放| 欧美一区二视频在线免费观看|