當今互聯網行業,大部分Web項目基本都是採用的先後端分離模式。前端爲H5項目,後端爲Java、PHP、Python等項目。並且大部分後端服務並不會只部署一套服務,而是會採用Nginx對後端服務進行負載均衡。那麼,此時就會出現一個問題了:若是一個請求url的 協議、域名、端口 三者之間任意一個與當前頁面url不一樣就會產生跨域的現象。那麼如何使用Nginx解決跨域問題呢?接下來,咱們就一塊兒探討下這個問題。javascript
出於瀏覽器的同源策略限制。同源策略(Sameoriginpolicy)是一種約定,它是瀏覽器最核心也最基本的安全功能,若是缺乏了同源策略,則瀏覽器的正常功能可能都會受到影響。能夠說Web是構建在同源策略基礎之上的,瀏覽器只是針對同源策略的一種實現。同源策略會阻止一個域的javascript腳本和另一個域的內容進行交互。所謂同源(即指在同一個域)就是兩個頁面具備相同的協議(protocol),主機(host)和端口號(port)。html
這裏,咱們利用Nginx的反向代理功能解決跨域問題,至於,什麼是Nginx的反向代理,你們就請自行百度或者谷歌吧。前端
Nginx做爲反向代理服務器,就是把http請求轉發到另外一個或者一些服務器上。經過把本地一個url前綴映射到要跨域訪問的web服務器上,就能夠實現跨域訪問。對於瀏覽器來講,訪問的就是同源服務器上的一個url。而Nginx經過檢測url前綴,把http請求轉發到後面真實的物理服務器。並經過rewrite命令把前綴再去掉。這樣真實的服務器就能夠正確處理請求,而且並不知道這個請求是來自代理服務器的。java
使用Nginx解決跨域問題時,咱們能夠編譯Nginx的nginx.conf配置文件,例如,將nginx.conf文件的server節點的內容編輯成以下所示。nginx
server {
location / {
root html;
index index.html index.htm;
//容許cros跨域訪問
add_header 'Access-Control-Allow-Origin' '*';
}
//自定義本地路徑
location /apis {
rewrite ^.+apis/?(.*)$ /$1 break;
include uwsgi_params;
proxy_pass http://www.binghe.com;
}
}
複製代碼
而後我把項目部署在nginx的html根目錄下,在ajax調用時設置url從http://www.binghe.com/apistest/test 變爲 www.binghe.com/apis/apiste…web
假設,以前我在頁面上發起的Ajax請求以下所示。ajax
$.ajax({
type:"post",
dataType: "json",
data:{'parameter':JSON.stringify(data)},
url:"http://www.binghe.com/apistest/test",
async: flag,
beforeSend: function (xhr) {
xhr.setRequestHeader("Content-Type", submitType.Content_Type);
xhr.setRequestHeader("user-id", submitType.user_id);
xhr.setRequestHeader("role-type", submitType.role_type);
xhr.setRequestHeader("access-token", getAccessToken().token);
},
success:function(result, status, xhr){
}
,error:function (e) {
layerMsg('請求失敗,請稍後再試')
}
});
複製代碼
修改爲以下的請求便可解決跨域問題。json
$.ajax({
type:"post",
dataType: "json",
data:{'parameter':JSON.stringify(data)},
url:"http:www.binghe.com/apis/apistest/test",
async: flag,
beforeSend: function (xhr) {
xhr.setRequestHeader("Content-Type", submitType.Content_Type);
xhr.setRequestHeader("user-id", submitType.user_id);
xhr.setRequestHeader("role-type", submitType.role_type);
xhr.setRequestHeader("access-token", getAccessToken().token);
},
success:function(result, status, xhr){
}
,error:function (e) {
layerMsg('請求失敗,請稍後再試')
}
});
複製代碼
好了,今天就聊到這兒吧!別忘了點個贊,給個在看和轉發,讓更多的人看到,一塊兒學習,一塊兒進步!!後端
若是你以爲冰河寫的還不錯,請微信搜索並關注「 冰河技術 」微信公衆號,跟冰河學習高併發、分佈式、微服務、大數據、互聯網和雲原生技術,「 冰河技術 」微信公衆號更新了大量技術專題,每一篇技術文章乾貨滿滿!很多讀者已經經過閱讀「 冰河技術 」微信公衆號文章,成功跳槽到大廠;也有很多讀者實現了技術上的飛躍,成爲公司的技術骨幹!若是你也想像他們同樣提高本身的能力,實現技術能力的飛躍,進大廠,升職加薪,那就關注「 冰河技術 」微信公衆號吧,天天更新超硬核技術乾貨,讓你對如何提高技術能力再也不迷茫!api