米利唐_后腰_乌克兰足球超级联赛_中国竞彩欧赔 - 足球竞彩分析

集團官網
  • 國家級全民數字素養與技能培訓基地
  • 河南省第一批產教融合型企業建設培育單位
  • 鄭州市數字技能人才(碼農)培養評價聯盟

前端開發中如何解決瀏覽器跨域問題?

編輯:云和數據 日期:2023-06-06 10:29

WEB前端開發中瀏覽器判斷是跨域請求會在請求頭上添加origin,表示這個請求來源哪里。比如:

PlaintextGET?/?HTTP/1.1Origin:?http://localhost:8601

服務器收到請求判斷這個Origin是否允許跨域,如果允許則在響應頭中說明允許該來源的跨域請求,如下:

PlaintextAccess-Control-Allow-Origin:http://localhost:8601

如果允許任何域名來源的跨域請求,則響應如下:

PlaintextAccess-Control-Allow-Origin:*

解決跨域的方法:

1、JSONP

通過script標簽的src屬性進行跨域請求,如果服務端要響應內容則首先讀取請求參數callback的值,callback是一個回調函數的名稱,服務端讀取callback的值后將響應內容通過調用callback函數的方式告訴請求方。如下圖:
1678851693396_圖片1.png

2、添加響應頭

服務端在響應頭添加 Access-Control-Allow-Origin:

3、通過nginx代理跨域

由于服務端之間沒有跨域,瀏覽器通過nginx去訪問跨域地址。

1678851748704_圖片2.png

1)瀏覽器先訪問http://192.168.101.10:8601 nginx提供的地址,進入頁面

2)此頁面要跨域訪問http://192.168.101.11:8601 ,不能直接跨域訪問http://www.baidu.com:8601 ,而是訪問nginx的一個同源地址,比如:http://192.168.101.11:8601/api ,通過http://192.168.101.11:8601/api 的代理去訪問http://www.baidu.com:8601。

這樣就實現了跨域訪問。

瀏覽器到http://192.168.101.11:8601/api 沒有跨域

nginx到http://www.baidu.com:8601通過服務端通信,沒有跨域。

我們準備使用方案2解決跨域問題。在內容管理的api工程config包下編寫GlobalCorsConfig.java,

或直接從課程資料/項目工程下拷貝,

代碼如下:

Javapackage?com.xuecheng.system.config;import?org.springframework.context.annotation.Bean;import?org.springframework.context.annotation.Configuration;import?org.springframework.web.cors.CorsConfiguration;import?org.springframework.web.cors.UrlBasedCorsConfigurationSource;import?org.springframework.web.filter.CorsFilter;/**?*?@description?跨域過慮器?*?@author?Mr.M?*?@date?2022/9/7?11:04?*?@version?1.0?*/?@Configuration?public?class?GlobalCorsConfig?{??/**???*?允許跨域調用的過濾器???*/??@Bean??public?CorsFilter?corsFilter()?{???CorsConfiguration?config?=?new?CorsConfiguration();???//允許白名單域名進行跨域調用???config.addAllowedOrigin("*");???//允許跨越發送cookie???config.setAllowCredentials(true);???//放行全部原始頭信息???config.addAllowedHeader("*");???//允許所有請求方法跨域調用???config.addAllowedMethod("*");???UrlBasedCorsConfigurationSource?source?=?new?UrlBasedCorsConfigurationSource();???source.registerCorsConfiguration("/**",?config);???return?new?CorsFilter(source);??}?}

此配置類實現了跨域過慮器,在響應頭添加Access-Control-Allow-Origin。

重啟系統管理服務,前端工程可以正常進入http://localhost:8601,觀察瀏覽器記錄,成功解決跨域。

1678851830143_圖片3.png

如果你對前端開發感興趣請點擊進入云和數據官網,我們有專業的客服老師為您答疑解惑。

云和數據ICT職業教育發揮公司產業化優勢與技術積淀,整合國內外優秀師資,累計自主研發230余項教輔、教材,300余項實踐教學案例與實訓平臺,采用六位一體項目制教學模式,年培養高端ICT技術人才超10000人,累計為企業輸送高端泛ICT技術人才超9萬人,學員60%來自于口碑推薦。云和數據人才培養技術方向涵蓋大數據、JAVA軟件工程、UI用戶體驗設計、前端開發、軟件測試、智能制造、虛擬現實、云計算、人工智能九大方向,以九大精品課程為基礎,八大就業基地為依托,一次就業率99.02%,61.9%就業薪資超1W,以大數據為首的精品專業平均薪資13.25K。

相關內容

搶先一步 鴻蒙(HarmonyOS)應用開發者高級認證 免費考! 適合人群計算機相關專業在校生(技師、中職、高職、本科、研究生)對鴻蒙(HarmonyOS)有興趣的非計算機相關專業在校生目前正在從事移動應用的開發者目前正在從事計算機行業相關的人計算機專業高校老師所有對鴻蒙(HarmonyOS)有興趣的人 培訓方案掌握鴻蒙的核心概念和端云一體化開發、... 什么是Java的多態性(polymorphism)?它有哪些不同的形式? 多態性是Java面向對象編程的一個重要概念,它允許不同的對象以一致的方式響應同一個方法調用,具體表現為對象在運行時可以表現出多個不同的形態。多態性主要有兩種不同的形式:編譯時多態性(靜態多態性)和運行時多態性(動態多態性)。1. 編譯時多態性(靜態多態性):   ... 如何學習和搭建Hadoop開發環境? Hadoop是大數據處理領域的重要平臺,能夠處理和分析大量數據。為了有效地利用Hadoop,我們需要學習其基礎知識,并正確搭建開發環境。下面是詳細的學習和搭建指南。一、學習Hadoop基礎掌握基礎概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統,Ma... UI 設計學習如何進階成為高手 我總結了六種方法,幫助你走出舒適區,提高技能,成長為自信且經驗豐富的UI設計高手一位經驗豐富的 UI 設計師,往往十分看中應用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經在 UI 設計圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因為陷入了一個舒適圈,UI技能一直原... 在Java中Executor和Executors的區別? 在Java中,Executor和Executors都與線程池和并發執行有關,但它們是不同的概念和類。1.ExecutorExecutor是一個接口,位于java.util.concurrent包中,用于表示一個執行任務的執行器。它只定義了一個方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡單的存儲類型。其value是字符串,不過根據字符串的格式不同,又可以分為3類:string是普通字符串,int整數類型,可以做自增、自減操作,float浮點類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經存在的...