隨著項目模塊越來越多,很多模塊現在都是獨立部署。模塊之間的交流有時可能會通過Cookie來完成。比如說門戶和應用,分別部署在不同的機器或者web容器中,假如用戶登陸之后會在瀏覽器客戶端寫入cookie(記錄著用戶上下文信息),應用想要獲取門戶下的cookie,這就產生了cookie跨域的問題。
解決cookie跨域問題之nginx反向代理
反向代理概念
反向代理(Reverse Proxy)方式是指以代理服務器來接受Internet上的連接請求,然后將請求轉發給內部網絡上的服務器;并將從服務器上得到的結果返回給Internet上請求連接的客戶端,此時代理服務器對外就表現為一個服務器。
反向代理服務器對于客戶端而言它就像是原始服務器,并且客戶端不需要進行任何特別的設置。客戶端向反向代理的命名空間(name-space)中的內容發送普通請求,接著反向代理將判斷向何處(原始服務器)轉交請求,并將獲得的內容返回給客戶端,就像這些內容原本就是它自己的一樣。
場景模擬
兩個工程web1, web2, 部署在同一臺機器上的不同tomcat上,請求web1工程的index.html,如下:
?
然后點擊鏈接請求web2工程的index.jsp,?內容如下:
再看一下nginx的配置:
利用nginx的方向代理來解決cookie跨域問題,其實是通過“欺騙”瀏覽器來實現的,通過nginx,我們可以將不同工程的cookie放到nginx域下,通過nginx反向代理就可以取到不同工程寫入的cookie。
其實上述場景中?$.cookie(“user”, “hjzgg”, {path: “/web”}); 中的path可以寫成 “/”, 這樣nginx的配置就更為簡單了,如下。
location /web1 { proxy_pass http://web1; proxy_set_header Host 127.0.0.1; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Cookie $http_cookie; log_subrequest on; } location /web2 { proxy_pass http://web2; proxy_set_header Host 127.0.0.1; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Cookie $http_cookie; log_subrequest on; }
更多Nginx相關技術文章,請訪問Nginx使用教程欄目進行學習!?