Nginx的反向代理跨域

什么是跨域咆蒿?

跨域是指a頁面想獲取b頁面資源东抹,如果a、b頁面的協(xié)議沃测、域名缭黔、端口、子域名不同蒂破,或是a頁面為ip地址馏谨, b頁面為域名地址,所進行的訪問行動都是跨域

產(chǎn)生的原因附迷?

瀏覽器為了安全問題一般都限制了跨域訪問惧互,也就是不允許跨域請求資源

同ip(或domain),同端口,同協(xié)議視為同一個域挟秤,一個域內(nèi)的腳本僅僅具有本域內(nèi)的權(quán)限壹哺,可以理解為本域腳本只能讀寫 本域內(nèi)的資源,而無法訪問其它域的資源艘刚。這種安全限制稱為同源策略

現(xiàn)代瀏覽器在安全性和可用性之間選擇了一個平衡點管宵。 在遵循同源策略的基礎(chǔ)上,選擇性地為同源策略“開放了后門”。例如img script style等標簽箩朴,都允許垮域引用資源,然而岗喉, 你也只能是引用這些資源而已,并不能讀取這些資源的內(nèi)容

同源策略限制以下幾種行為:

1.Cookie炸庞、LocalStorage 和 IndexDB 無法讀取

2.DOM 和 Js對象無法獲得

3.AJAX 請求不能發(fā)送

常見跨域場景

http://www.domain.com/a.jshttp://www.domain.com/b.js 同一域名钱床,不同文件或路徑 允許http://www.domain.com/lab/c.jshttp://www.domain.com:8000/a.jshttp://www.domain.com/b.js 同一域名,不同端口 不允許http://www.domain.com/a.jshttps://www.domain.com/b.js 同一域名埠居,不同協(xié)議 不允許http://www.domain.com/a.jshttp://192.168.4.12/b.js 域名和域名對應(yīng)相同ip 不允許http://www.domain.com/a.jshttp://x.domain.com/b.js 主域相同查牌,子域不同 不允許http://domain.com/c.jshttp://www.domain1.com/a.jshttp://www.domain2.com/b.js 不同域名 不允許

跨域解決方案

1、 通過jsonp跨域

2滥壕、 document.domain + iframe跨域

3纸颜、 location.hash + iframe

4、 window.name + iframe跨域

5绎橘、 postMessage跨域

6胁孙、 跨域資源共享(CORS)

7、 nginx代理跨域

8称鳞、 nodejs中間件代理跨域

9涮较、 WebSocket協(xié)議跨域

nginx反向代理解決跨域

正向代理:代理位于網(wǎng)站和客戶端中間, 客戶端無法訪問某網(wǎng)站冈止,就將請求發(fā)送給代理服務(wù)器狂票,代理從網(wǎng)站取回來再發(fā)送給客戶端,網(wǎng)站并不知道為誰提供服務(wù)

反向代理:客戶端訪問某網(wǎng)站的一個頁面靶瘸, 但是網(wǎng)站并沒有苫亦,就偷偷從另外一臺服務(wù)器上取回來,然后作為自己的內(nèi)容吐給用戶,用戶不知道真正提供服務(wù)的是誰

對于瀏覽器來說怨咪,訪問的就是同源服務(wù)器上的一個url屋剑。而nginx通過 檢測url前綴,把http請求轉(zhuǎn)發(fā)到后面真實的物理服務(wù)器诗眨。并通過rewrite命令把前綴再去掉唉匾。這樣真實的服務(wù)器就可以正確 處理請求,并且并不知道這個請求是來自代理服務(wù)器的匠楚。

簡單說巍膘,nginx服務(wù)器欺騙了瀏覽器,讓它認為這是同源調(diào)用芋簿,從而解決了瀏覽器的跨域問題峡懈。又通過重寫url,欺騙了真實 的服務(wù)器与斤,讓它以為這個http請求是直接來自與用戶瀏覽器的肪康。

Location/carrots-admin-ajax/{

????proxy_passhttp://dev.admin.carrots.ptteng.com/;

}

proxy_pass把請求代理到其他主機

兩種寫法hhttp://dev.admin.carrots.ptteng.com/? ? 和? ? ?http://dev.admin.carrots.ptteng.com

????如果訪問url =http://server/html/test.jsp荚恶,則被nginx代理后

? ? ? ? 情況1,將test/作為根路徑磷支,請求test/路徑下的資源谒撼。

? ? ? ? 情況2,則被nginx代理后雾狈,請求路徑會變?yōu)閔ttp://proxy_pass/test.jsp廓潜,直接訪問server的根資源。

/carrots-admin-ajax/

是一個匹配規(guī)則善榛,用于攔截請求辩蛋,匹配任何以/proxy/html/開頭的地址,匹配符合以后移盆,停止往下搜索正則堪澎。

對于瀏覽器來說,訪問的就是同源服務(wù)器上的一個url味滞。而nginx通過檢測url前綴,把http請求轉(zhuǎn)發(fā)到后面真實的物理服務(wù)器钮呀。并通過rewrite命令把前綴再去掉剑鞍。這樣真實的服務(wù)器就可以正確處理請求,并且并不知道這個請求是來自代理服務(wù)器的爽醋。

簡單說蚁署,nginx服務(wù)器欺騙了瀏覽器,讓它認為這是同源調(diào)用蚂四,從而解決了瀏覽器的跨域問題光戈。又通過重寫url,欺騙了真實的服務(wù)器遂赠,讓它以為這個http請求是直接來自與用戶瀏覽器的久妆。

nginx rewrite指令執(zhí)行順序:

1.執(zhí)行server塊的rewrite指令(這里的塊指的是server關(guān)鍵字后{}包圍的區(qū)域,其它xx塊類似)

2.執(zhí)行l(wèi)ocation匹配

3.執(zhí)行選定的location中的rewrite指令

如果其中某步URI被重寫跷睦,則重新循環(huán)執(zhí)行1-3筷弦,直到找到真實存在的文件

如果循環(huán)超過10次,則返回500 Internal Server Error錯誤

7.參考文獻

參考一:https://www.cnblogs.com/gabrielchen/p/5066120.html

參考二:http://blog.csdn.net/shendl/article/details/48443299

8.更多討論

提問:

Q:例如img script style等標簽抑诸,都允許垮域引用資源烂琴?

A:在瀏覽器中,并且加載的方式其實相當(dāng)于一次普通的GET請求蜕乡,唯一不同的是奸绷,為了安全起見攻锰,瀏覽器不允許這種方式下對加載到的資源的讀寫操作挑胸,而只能使用標簽本身應(yīng)當(dāng)具備的能力(比如腳本執(zhí)行、樣式應(yīng)用等等)巴碗。

Q:例如img script style等標簽,都允許垮域引用資源扣癣?

A:在瀏覽器中惰帽,并且加載的方式其實相當(dāng)于一次普通的GET請求,唯一不同的是父虑,為了安全起見该酗,瀏覽器不允許這種方式下對加載到的資源的讀寫操作,而只能使用標簽本身應(yīng)當(dāng)具備的能力(比如腳本執(zhí)行士嚎、樣式應(yīng)用等等)呜魄。

Q:JSONP和nginx跨域有什么不同

JSONP和nginx是完全不同的 是可以跨域的,而且在跨域腳本中可以直接回調(diào)當(dāng)前腳本的函數(shù)

原理:是可以跨域的莱衩,而且在跨域腳本中可以直接回調(diào)當(dāng)前腳本的函數(shù)

script標簽是可以加載異域的JavaScript并執(zhí)行的爵嗅,通過預(yù)先設(shè)定好的callback函數(shù)來實現(xiàn)和母頁面的交互。它有一個大名笨蚁,叫做JSONP跨域睹晒,JSONP是JSON with Padding的略稱。它是一個非官方的協(xié)議括细,明明是加載script伪很,為啥和JSON扯上關(guān)系呢?原來就是這個callback函數(shù)奋单,對它的使用有一個典型的方式锉试,就是通過JSON來傳參,即將JSON數(shù)據(jù)填充進回調(diào)函數(shù)览濒,這就是JSONP的JSON+Padding的含義呆盖。JSONP只支持GET請求。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贷笛,一起剝皮案震驚了整個濱河市应又,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌昨忆,老刑警劉巖丁频,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異邑贴,居然都是意外死亡席里,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門拢驾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來奖磁,“玉大人,你說我怎么就攤上這事繁疤】” “怎么了秕狰?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長躁染。 經(jīng)常有香客問我鸣哀,道長,這世上最難降的妖魔是什么吞彤? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任我衬,我火速辦了婚禮,結(jié)果婚禮上饰恕,老公的妹妹穿的比我還像新娘挠羔。我一直安慰自己,他們只是感情好埋嵌,可當(dāng)我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布破加。 她就那樣靜靜地躺著,像睡著了一般雹嗦。 火紅的嫁衣襯著肌膚如雪范舀。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天了罪,我揣著相機與錄音尿背,去河邊找鬼。 笑死捶惜,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的荔烧。 我是一名探鬼主播吱七,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鹤竭!你這毒婦竟也來了踊餐?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤臀稚,失蹤者是張志新(化名)和其女友劉穎吝岭,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體吧寺,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡窜管,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了稚机。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片幕帆。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖赖条,靈堂內(nèi)的尸體忽然破棺而出失乾,到底是詐尸還是另有隱情常熙,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布碱茁,位于F島的核電站裸卫,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏纽竣。R本人自食惡果不足惜墓贿,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望退个。 院中可真熱鬧募壕,春花似錦、人聲如沸语盈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽刀荒。三九已至代嗤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間缠借,已是汗流浹背干毅。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留泼返,地道東北人硝逢。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像绅喉,于是被迫代替她去往敵國和親渠鸽。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 什么是跨域柴罐? 2.) 資源嵌入:徽缚、、革屠、等dom標簽凿试,還有樣式中background:url()、@font-fac...
    電影里的夢i閱讀 2,368評論 0 5
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理似芝,服務(wù)發(fā)現(xiàn)那婉,斷路器,智...
    卡卡羅2017閱讀 134,629評論 18 139
  • 試試超鏈接
    彥頁生_yansheng閱讀 140評論 0 0
  • 前言 不知道出于某種原因党瓮,讓我突然冒出想用JavaScript解析GIF的念頭吧恃。于是我花費了數(shù)天的時間去研究這玩意...
    JetLu閱讀 2,207評論 0 0
  • 那些個仲夏夜的你與那星斗一樣格外清晰, 漫談詩歌的我們坐在草場上麻诀, 那些日子有你也有詩痕寓。 而遠方的日子總是在短暫的...
    董之堯閱讀 261評論 4 3