解讀前后端分離項(xiàng)目的跨域問(wèn)題
跨域問(wèn)題的原因
根本原因:瀏覽器有同源策略限制,當(dāng)前域名的js只能讀取同城下的窗口屬性,這是一個(gè)基礎(chǔ)安全功能
同源策略
若兩資源的URL中的協(xié)議、域名、端口都相同就成為同源,如果兩資源不同源,則不允許共享資源。
例如:http://www.baidu.com/a/hello.html
請(qǐng)求地址 | 結(jié)果 | 原因 |
http://www.baidu.com/a/java.html | 成功 | 同一域名端口,相同文件夾 |
http://www.baidu.com/b/hello.html | 成功 | 同一域名端口,不同文件夾 |
https://www.baidu.com/a/hello.html | 失敗 | 不同協(xié)議,http與https |
http://www.baidu.com:8081/a/java.html | 失敗 | 不同端口,默認(rèn)為8080端口 |
http://www.sina.com:8081/a/java.html | 失敗 | 不同域名 |
跨域CORS
跨域就是解決不同域之間可以進(jìn)行資源的相互訪問(wèn),為了避開(kāi)瀏覽器的同源政策
CORS出現(xiàn)之前
瀏覽器接收到服務(wù)器回復(fù)—>檢查是否同源—>同源就響應(yīng),不同源就拒絕相應(yīng)
CORS出現(xiàn)之后
瀏覽器接收到服務(wù)器回復(fù) --> 檢查一下response header --> 發(fā)現(xiàn)有特定字段Access-Control-Allow-Origin --> 檢查這個(gè)header后面的值包不包含自己所在的域(打比方我們現(xiàn)在在www.baidu.com),瀏覽器檢查發(fā)現(xiàn)后response header里面寫的有Access-Control-Allow-Origin: https://www.baidu.com, 并且https://www.google.com正好我們?cè)谠试S的域里面! --> 瀏覽器響應(yīng)服務(wù)器返回的數(shù)據(jù)(response)。
瀏覽器要實(shí)現(xiàn)的內(nèi)容:
- 接收到服務(wù)器的回復(fù)之后檢測(cè)回復(fù)頭里面是否含有特定字段!
- 有的話查看自己的域名是否在內(nèi),一定要這兩個(gè)條件都符合!
- 瀏覽器才會(huì)接受(或者說(shuō)響應(yīng))服務(wù)器返回的回復(fù)!
服務(wù)器需要實(shí)現(xiàn)的內(nèi)容:
- 服務(wù)器需要在接受到瀏覽器發(fā)來(lái)的請(qǐng)求(request)后,在返回response之前!
- 設(shè)置header,在header中里面包含特定字段,以便瀏覽器收到回復(fù)之后可以去檢查,有字段證明服務(wù)器同意服務(wù)這個(gè)網(wǎng)站,瀏覽器就可以接受回復(fù),沒(méi)有字段或者字段的值不包含發(fā)送請(qǐng)求的網(wǎng)站,瀏覽器就不會(huì)響應(yīng)回復(fù)內(nèi)容!
后端解決跨域問(wèn)題的幾種方式
第一種:在application文件里
第二種:在配置類里加上注解
第三種:在過(guò)濾器里設(shè)置
@WebFilter(filterName = "CorsFilter ") @Configuration public class CorsFilter implements Filter { @Override public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { HttpServletResponse response = (HttpServletResponse) res; response.setHeader("Access-Control-Allow-Origin","*"); response.setHeader("Access-Control-Allow-Credentials", "true"); response.setHeader("Access-Control-Allow-Methods", "POST, GET, PATCH, DELETE, PUT"); response.setHeader("Access-Control-Max-Age", "3600"); response.setHeader("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept"); HttpServletRequest httpRequest = (HttpServletRequest) req; // OPTIONS method response if (httpRequest.getMethod().equals("OPTIONS")) ((HttpServletResponse) res).sendError(HttpServletResponse.SC_OK); chain.doFilter(req, res); } }
跨域的前端處理
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Eclipse 項(xiàng)目出現(xiàn)錯(cuò)誤(紅色嘆號(hào))解決方法
這篇文章主要介紹了Eclipse 項(xiàng)目出現(xiàn)錯(cuò)誤(紅色嘆號(hào))解決方法的相關(guān)資料,需要的朋友可以參考下2017-06-06基于SpringMVC實(shí)現(xiàn)網(wǎng)頁(yè)登錄攔截
SpringMVC的處理器攔截器類似于Servlet開(kāi)發(fā)中的過(guò)濾器Filter,用于對(duì)處理器進(jìn)行預(yù)處理和后處理。因此,本文將為大家介紹如何通過(guò)SpringMVC實(shí)現(xiàn)網(wǎng)頁(yè)登錄攔截功能,需要的小伙伴可以了解一下2021-12-12Intellij IDEA 關(guān)閉和開(kāi)啟自動(dòng)更新的提示?
這篇文章主要介紹了Intellij IDEA 關(guān)閉和開(kāi)啟自動(dòng)更新的提示操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04解決Maven 項(xiàng)目報(bào)錯(cuò) java.httpservlet和synchronized使用方法
下面小編就為大家?guī)?lái)一篇解決Maven 項(xiàng)目報(bào)錯(cuò) java.httpservlet和synchronized使用方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07SpringBoot中REST API 接口傳參的實(shí)現(xiàn)
我們?cè)陂_(kāi)發(fā)?REST API?的過(guò)程中,經(jīng)常需要傳遞參數(shù),本文主要介紹了SpringBoot中REST API 接口傳參的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12