Nginx如何解決cookie跨域

隨著項目模塊越來越多,很多模塊現在都是獨立部署。模塊之間的交流有時可能會通過Cookie來完成。比如說門戶和應用,分別部署在不同的機器或者web容器中,假如用戶登陸之后會在瀏覽器客戶端寫入cookie(記錄著用戶上下文信息),應用想要獲取門戶下的cookie,這就產生了cookie跨域的問題。  

Nginx如何解決cookie跨域

解決cookie跨域問題之nginx反向代理

反向代理概念

反向代理(Reverse Proxy)方式是指以代理服務器來接受Internet上的連接請求,然后將請求轉發給內部網絡上的服務器;并將從服務器上得到的結果返回給Internet上請求連接的客戶端,此時代理服務器對外就表現為一個服務器。

反向代理服務器對于客戶端而言它就像是原始服務器,并且客戶端不需要進行任何特別的設置。客戶端向反向代理的命名空間(name-space)中的內容發送普通請求,接著反向代理將判斷向何處(原始服務器)轉交請求,并將獲得的內容返回給客戶端,就像這些內容原本就是它自己的一樣。

場景模擬

兩個工程web1, web2, 部署在同一臺機器上的不同tomcat上,請求web1工程的index.html,如下:

?Nginx如何解決cookie跨域

然后點擊鏈接請求web2工程的index.jsp,?內容如下:

Nginx如何解決cookie跨域

再看一下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使用教程欄目進行學習!?

? 版權聲明
THE END
喜歡就支持一下吧
點贊9 分享