elasticsearch入門系列">elasticsearch入門系列
734
2022-05-30
@TOC
前言
1.跨域產(chǎn)生的原因
跨域請求存在的原因:由于瀏覽器的同源策略,即屬于不同域的頁面之間不能相互訪問各自的頁面內(nèi)容。
2.解決跨域的方案
2.1 前端的方式
1.imge.src,script.src,style.href 不受同源策略的影響可以加載其他域的資源,可以用這個特性,向服務器發(fā)送數(shù)據(jù)。最常用的就是使用image.src 向服務器發(fā)送前端的錯誤信息。image.src 和style.href 是無法獲取服務器的數(shù)據(jù)返回的,script.src 服務器端配合可以得到數(shù)據(jù)返回。
2.possMessage,window.name,document.domain 是兩個窗口直接相互傳遞數(shù)據(jù)。
(1)possMessage 是HTML5中新增的,使用限制是 必須獲得窗口的window 引用。IE8+支持,firefox,chrome,safair,opera支持
(2)window.name ,在一個頁面中打開另一個頁面時,window.name 是共享的,所以可以通過window.name 來傳遞數(shù)據(jù),window.name的限制大小是2M,這個所有瀏覽器都支持,且沒有什么限制。
(3) document.domain 將兩個頁面的document.domain 設置成相同,document.domain 只能設置成父級域名,既可以訪問,使用限制:這頂級域名必須相同
2.2 后端方式
CORS 是w3c標準的方式,通過在web服務器端設置:響應頭Access-Cntrol-Alow-Origin 來指定哪些域可以訪問本域的數(shù)據(jù)。
ie8&9(XDomainRequest),10+,chrom4 ,firefox3.5,safair4,opera12支持這種方式。
一、ASP.NET Core中間件實現(xiàn)CORS
1.中間件代碼
using Microsoft.AspNetCore.Http; using System.Threading.Tasks; namespace Core.Api { ///
2.在管道中的使用
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseMiddleware
ASP ASP.NET
版權(quán)聲明:本文內(nèi)容由網(wǎng)絡用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔相應法律責任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實后本網(wǎng)站將在24小時內(nèi)刪除侵權(quán)內(nèi)容。