色综合老司机第九色激情 _中文字幕日韩av资源站_国产+人+亚洲_久久久精品影院_久久久视频免费观看_欧美激情亚洲自拍_亚洲成av人片在线观看香蕉_热草久综合在线_欧美极品第一页_2020国产精品自拍

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 爆破專欄丨Spring Security系列教程解決Spring Security環境中的跨域問題

爆破專欄丨Spring Security系列教程解決Spring Security環境中的跨域問題

來源:千鋒教育
發布人:qyf
時間: 2021-10-29 11:40:00 1635478800

  原創:千鋒一一哥

  前言

  上一章節中,一一哥 給各位講解了同源策略和跨域問題,以及跨域問題的解決方案,在本篇文章中,我會帶大家進行代碼實現,看看在Spring Security環境中如何解決跨域問題。

  一. 啟用Spring Security 的CORS支持

  1. 創建web接口

  我先在SpringBoot環境中,創建一個端口號為8080的web項目,注意這個web項目沒有引入Spring Security的依賴包。然后在其中創建一個IndexController,定義兩個測試接口以便被ajax進行跨域訪問。8080項目的代碼結構:

  @RestController

  public class IndexController {

  @GetMapping("/hello")

  public String hello() {

  return "get hello";

  }

  @PostMapping("/hello")

  public String hello2() {

  return "post hello";

  }

  }

  請參考如下代碼結構進行項目創建。

圖片1

  2. 執行ajax請求

  我們接下來再創建另一個端口號為8082的web項目,注意這個web項目也沒有引入Spring Security的依賴包。接著在這里定義一個index.html頁面,利用ajax跨域訪問8080項目中的web接口。

  8082項目的代碼結構:

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>Index</title>

    <script type="text/javascript" src="jquery-2.1.0.js"></script>

</head>

<body>

<div id="app"></div>

<input type="button" onclick="btnClick()" value="get請求">

<input type="button" onclick="btnClick2()" value="post請求">

 

<script>

    function btnClick() {

        $.get('http://localhost:8080/hello', function (msg) {

            $("#app").html(msg);

        });

    }

 

    function btnClick2() {

        $.post('http://localhost:8080/hello', function (msg) {

            $("#app").html(msg);

        });

    }

</script>

 

</body>

</html>  

  請參考如下代碼結構進行項目創建。

圖片2

  3. 發起跨域請求

  我們訪問8082項目中的index.html頁面,然后分別執行get與post請求,這時候就可以在瀏覽器的控制臺上看到產生了CORS跨域問題,出現了CORS error狀態,在請求頭中出現了Referer Policy: strict-origin-when-cross-origin。

圖片3

圖片4

  4. 解決跨域問題

  既然現在產生了跨域問題,那么該怎么解決呢?其實我們可以采用如下兩種方式之一來解決跨域問題。

  方式1:在接口方法上利用@CrossOrigin注解解決跨域問題

  @RestController

  public class IndexController {

  @CrossOrigin(value = "http://localhost:8082")

  @GetMapping("/hello")

  public String hello() {

  return "get hello";

  }

  @CrossOrigin(value = "http://localhost:8082")

  @PostMapping("/hello")

  public String hello2() {

  return "post hello";

  }

  }

  方式2:通過實現WebMvcConfigurer接口來解決跨域問題

  @Configuration

  public class WebMvcConfig implements WebMvcConfigurer {

  @Override

  public void addCorsMappings(CorsRegistry registry) {

  registry.addMapping("/**")

  .allowedOrigins("http://localhost:8082")

  .allowedMethods("*")

  .allowedHeaders("*");

  }

  }

  當進行了跨域設置之后,我們再次進行跨域請求,就可以看到請求成功了。

圖片5

  二. Spring Security環境下的跨域問題解決

  1. 引入Spring Security依賴

  通過上面的配置,我們已經解決了Ajax的跨域請求問題,但是這個案例中也有潛在的威脅存在,常見的就是 CSRF(Cross-site request forgery) 跨站請求偽造??缯菊埱髠卧煲脖环Q為 one-click attack 或者 session riding,通??s寫為 CSRF 或者 XSRF,是一種挾制用戶在當前已登錄的 Web 應用程序上執行非本意的操作的攻擊方法。

  所以為了提高網站的安全性,我在上面Spring Boot項目的基礎之上,添加Spring Security的依賴包,但是暫時不進行任何別的操作。

  <dependencies>

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-web</artifactId>

        </dependency>

 

        <dependency>

            <groupId>org.springframework.boot</groupId>

            <artifactId>spring-boot-starter-security</artifactId>

        </dependency>

    </dependencies>

  2. 重啟8080項目進行測試

  接著我就重啟8080這個Spring Boot項目,然后在8082項目中再次進行跨域請求,我們會發現在引入Spring Security后,再次產生了跨域問題。

圖片6

  3. 解決Spring Security環境下跨域問題的3種方案

  通過實驗可知,如果使用了 Spring Security,上面的跨域配置會失效,因為請求會被 Spring Security 攔截。那么在Spring Security環境中,如何解決跨域問題呢?這里我們有3種方式可以開啟 Spring Security 對跨域的支持。

  3.1 方式一:開啟cors方法

  我們在上面的案例之上,編寫一個SecurityConfig配置類,在configure方法中,利用cors() 開啟Spring Security 對 CORS 的支持:

  @EnableWebSecurity

  public class SecurityConfig extends WebSecurityConfigurerAdapter {

  @Override

  protected void configure(HttpSecurity http) throws Exception {

  http.authorizeRequests()

  .anyRequest()

  .permitAll()

  .and()

  .formLogin()

  .permitAll()

  .and()

  .httpBasic()

  .and()

  //支持跨域訪問

  .cors()

  .and()

  .csrf()

  .disable();

  }

  }

  3.2 方式二:進行全局配置

  第二種方式是去除上面的跨域配置,直接在 Spring Security 中做全局配置,如下:

  @EnableWebSecurity

  public class SecurityConfig extends WebSecurityConfigurerAdapter {

  @Override

  protected void configure(HttpSecurity http) throws Exception {

  http.authorizeRequests()

  .anyRequest()

  .permitAll()

  .and()

  .formLogin()

  .permitAll()

  .and()

  .httpBasic()

  .and()

  //支持跨域訪問

  .cors()

  .configurationSource(corsConfigurationSource())

  .and()

  .csrf()

  .disable();

  }

  @Bean

  public CorsConfigurationSource corsConfigurationSource() {

  UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();

  CorsConfiguration configuration = new CorsConfiguration();

  configuration.setAllowCredentials(true);

  configuration.setAllowedOrigins(Collections.singletonList("*"));

  configuration.setAllowedMethods(Collections.singletonList("*"));

  configuration.setAllowedHeaders(Collections.singletonList("*"));

  configuration.setMaxAge(Duration.ofHours(1));

  source.registerCorsConfiguration("/**", configuration);

  return source;

  }

  }

  以上2個方法,都可以實現在Spring Security環境下的跨域訪問。

  3.3 方式三:支持OAuth2的跨域訪問

  我們開發時,還有一種情況就是支持 OAuth2 相關接口的跨域,比如用戶要訪問 OAuth2 中的 /oauth/token 等接口。我們可以配置一個全局的 CorsFilter 跨域過濾器類,核心代碼如下:

  /**

  * 跨域配置方式3:定義全局跨域過濾器

  **/

  @Configuration

  public class GlobalCorsConfiguration {

  @Bean

  public CorsFilter corsFilter() {

  CorsConfiguration corsConfiguration = new CorsConfiguration();

  corsConfiguration.setAllowCredentials(true);

  corsConfiguration.addAllowedOrigin("*");

  corsConfiguration.addAllowedHeader("*");

  corsConfiguration.addAllowedMethod("*");

  UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource = new UrlBasedCorsConfigurationSource();

  urlBasedCorsConfigurationSource.registerCorsConfiguration("/**", corsConfiguration);

  return new CorsFilter(urlBasedCorsConfigurationSource);

  }

  }

  @EnableWebSecurity

  public class SecurityConfig extends WebSecurityConfigurerAdapter {

  @Override

  protected void configure(HttpSecurity http) throws Exception {

  //跨域方式3:

  http.requestMatchers()

  .antMatchers(HttpMethod.OPTIONS, "/oauth/**")

  .and()

  .csrf()

  .disable()

  .formLogin()

  .and()

  .cors();

  }

  }

  該方式也可以實現Spring Security中的跨域訪問。

  4. 代碼結構

  以下是本案例的代碼結構,可以參考下圖進行項目創建:

圖片7

  至此,我就帶各位解決了Spring Security環境中的跨域問題,你學會了嗎?

圖片8

關注WX公眾號【Java架構棧】,跟著千鋒一起學Java

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
色综合老司机第九色激情 _中文字幕日韩av资源站_国产+人+亚洲_久久久精品影院_久久久视频免费观看_欧美激情亚洲自拍_亚洲成av人片在线观看香蕉_热草久综合在线_欧美极品第一页_2020国产精品自拍
欧美成人aa大片| 日韩一区二区在线播放| 制服丝袜亚洲播放| 国产九九视频一区二区三区| 一区二区三区在线高清| 欧美va天堂va视频va在线| 9色porny自拍视频一区二区| 免费国产亚洲视频| 亚洲在线一区二区三区| 色菇凉天天综合网| 成人免费精品视频| 免费高清在线一区| 丝袜亚洲另类欧美| 亚洲午夜影视影院在线观看| 欧美国产激情一区二区三区蜜月| 欧美日韩mp4| 欧美探花视频资源| 欧美在线观看一区二区| 99国产精品视频免费观看| 国产麻豆视频一区| 韩国女主播一区二区三区| 日韩av午夜在线观看| 日产精品久久久久久久性色| 亚洲图片一区二区| 欧美国产日本韩| 中文字幕第一区二区| 中文字幕在线不卡一区二区三区| 中文字幕一区av| 亚洲色图一区二区三区| 亚洲欧美日韩中文播放| 亚洲一区二区三区影院| 日韩精品色哟哟| 精品一区二区在线视频| 玖玖九九国产精品| 亚洲一区二区三区四区在线观看 | 亚洲人成网站色在线观看| 一区二区高清在线| 奇米777欧美一区二区| 亚洲在线中文字幕| 蜜臀av国产精品久久久久| 午夜在线电影亚洲一区| 秋霞影院一区二区| 国产精品资源在线看| 午夜精品视频一区| 国内精品久久久久影院一蜜桃| 日韩激情视频网站| 天天操天天干天天综合网| 国产福利91精品| 99久精品国产| 高清成人免费视频| 成av人片一区二区| 日韩精品自拍偷拍| 一区二区三区中文字幕电影| 国产精品一卡二卡| 欧美男男青年gay1069videost| 久久网站热最新地址| 精久久久久久久久久久| 国产一区不卡视频| 日本不卡高清视频| 成人小视频免费在线观看| 欧美三级电影网站| 精品国产一区二区精华| 亚洲精品一卡二卡| 国产成人鲁色资源国产91色综| 5月丁香婷婷综合| 亚洲午夜成aⅴ人片| 欧美色倩网站大全免费| 亚洲一区二区三区自拍| 亚洲久本草在线中文字幕| 国产网红主播福利一区二区| 九色综合国产一区二区三区| av一区二区三区| 亚洲欧洲av在线| 91在线高清观看| 一区二区三区成人| 亚洲欧美偷拍三级| 欧美日韩一二三| 午夜久久电影网| 精品剧情v国产在线观看在线| 日韩电影网1区2区| 国产嫩草影院久久久久| 日本午夜精品视频在线观看 | 波多野结衣一区二区三区| 国产欧美综合在线| 欧美在线你懂的| 另类的小说在线视频另类成人小视频在线 | 亚洲影视资源网| 91精品福利在线一区二区三区 | 蜜臀av一级做a爰片久久| 日韩欧美不卡一区| 日韩不卡一区二区| heyzo一本久久综合| 欧美sm美女调教| 91首页免费视频| 日韩国产高清影视| 亚洲欧美日韩一区二区 | 欧美羞羞免费网站| 国产精品一二三四五| 精品国产91久久久久久久妲己 | 亚洲欧美在线aaa| 欧美日韩国产中文| www.99精品| 国产另类ts人妖一区二区| 亚洲国产精品久久久男人的天堂| 在线免费亚洲电影| 色综合欧美在线| 国产精品 欧美精品| 久久国产夜色精品鲁鲁99| 午夜不卡av在线| 亚洲国产精品嫩草影院| 亚洲成人777| 亚洲第一搞黄网站| 午夜精品aaa| 蜜臀av国产精品久久久久| 亚洲国产另类av| 午夜一区二区三区视频| 亚洲va欧美va人人爽午夜| 天天色图综合网| 久久99国产精品麻豆| 蜜乳av一区二区三区| 毛片av一区二区三区| 久久激五月天综合精品| 国产精品影视在线| 99精品久久只有精品| 91久久精品一区二区三区| 欧美少妇xxx| 精品剧情在线观看| 久久只精品国产| 久久久久国产精品麻豆| 亚洲国产电影在线观看| 这里只有精品99re| 欧美成人女星排名| 欧美国产激情一区二区三区蜜月| 综合久久综合久久| 日本最新不卡在线| 懂色av中文字幕一区二区三区| 91欧美激情一区二区三区成人| 欧美日韩免费不卡视频一区二区三区 | 免费av网站大全久久| 国产成人欧美日韩在线电影| 色哟哟在线观看一区二区三区| 色8久久精品久久久久久蜜| www一区二区| 一区二区三区色| 成人黄色777网| 欧美色图片你懂的| 久久夜色精品国产噜噜av| 亚洲一区二区三区四区在线观看 | 91免费观看在线| 美女网站视频久久| 色狠狠综合天天综合综合| 精品久久人人做人人爱| 亚洲成人免费视频| 国产九色sp调教91| 久久蜜桃香蕉精品一区二区三区| 图片区小说区国产精品视频| av网站一区二区三区| 中文字幕不卡在线播放| 国产麻豆成人精品| 久久久午夜精品| 成人免费av资源| 国产精品沙发午睡系列990531| 老司机午夜精品99久久| 91精品国模一区二区三区| 亚洲在线视频网站| 在线视频综合导航| 亚洲国产成人私人影院tom| 成人在线综合网| 中文字幕亚洲一区二区av在线| 97se狠狠狠综合亚洲狠狠| 亚洲一区二区三区四区在线观看 | 久久99精品久久只有精品| 欧美一区二区三区电影| 加勒比av一区二区| 欧美一区二区三区视频在线| 青草av.久久免费一区| 欧美日韩一区三区四区| 日韩高清在线不卡| 日本韩国一区二区| 蜜桃视频一区二区三区在线观看| 日韩午夜激情av| www.日韩精品| 热久久免费视频| 亚洲日本欧美天堂| 日韩精品一区二区三区四区| 不卡视频一二三| 国产一区二区三区在线观看精品 | 欧美高清在线精品一区| 欧美日韩国产一二三| 成人在线一区二区三区| 男女性色大片免费观看一区二区 | 国产精品视频一二三区| 国产一区二区三区美女| 一区二区三区在线免费视频| 久久久久国产精品免费免费搜索| 色综合久久久久综合体桃花网| 亚洲图片欧美视频| 中文字幕亚洲一区二区va在线| 日韩欧美国产综合| 91麻豆精品久久久久蜜臀|