欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Angular4如何開發(fā)解決跨域問題-創(chuàng)新互聯(lián)

這篇文章主要介紹了Angular4如何開發(fā)解決跨域問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供布爾津網(wǎng)站建設(shè)、布爾津做網(wǎng)站、布爾津網(wǎng)站設(shè)計、布爾津網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、布爾津企業(yè)網(wǎng)站模板建站服務(wù),10多年布爾津做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

1.跨域

瀏覽器對于javascript的同源策略的限制,例如a.cn下面的js不能調(diào)用b.cn中的js,對象或數(shù)據(jù)(因為a.cn和b.cn是不同域),所以跨域就出現(xiàn)了.

上面提到的,同域的概念又是什么呢??? 簡單的解釋就是相同域名,端口相同,協(xié)議相同

同源策略:

請求的url地址,必須與瀏覽器上的url地址處于同域上,也就是域名,端口,協(xié)議相同.

比如:我在本地上的域名是study.cn,請求另外一個域名一段數(shù)據(jù),這個時候在瀏覽器上會報錯,這個就是同源策略的保護(hù),如果瀏覽器對javascript沒有同源策略的保護(hù),那么一些重要的機(jī)密網(wǎng)站將會很危險~

2.反向代理

反向代理(Reverse Proxy)方式是指以代理服務(wù)器來接受internet上的連接請求,然后將請求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給internet上請求連接的客戶端,此時代理服務(wù)器對外就表現(xiàn)為一個反向代理服務(wù)器。

3.Angular4跨域

Angular4項目分為工程代碼和生產(chǎn)代碼,在本地調(diào)試一般都是工程代碼,這樣聯(lián)調(diào)接口的話,每次寫一個接口都要丟到服務(wù)器上測試,嚴(yán)重影響效率,所以我們需要做的就是能在工程項目上聯(lián)調(diào)接口,隨時能看到效果,但是后端代碼不是部署在本機(jī)的話就會有跨域問題,于是我們便需要去著重去解決跨域問題!這樣后端代碼隨時改,前端也可以隨時更改看到效果,實現(xiàn)真正的前后端分離!
對于Angular4解決跨域問題,應(yīng)該是開發(fā)者已經(jīng)想到這個問題,所以解決這個問題很簡單!那就是反向代理!!

下面介紹反向代理的方法:

1.首先需要建立一個JSON文件,文件名”proxy.config.json”

{
 "/api":{
  "target":"http://106.15.179.92"
 }
}

http://106.15.179.92:為你連接機(jī)器的ip地址,或者你所需要請求的接口域名,這個就是需要被代理的

/api是代理的名稱,一般都是接口請求的ip地址后面的第一個參數(shù)名

比如:http://106.15.179.92/api/fron...為一個登錄的接口,反向代理后寫接口請求的時候只需要寫

this.$http.post(`/api/front/frontUserController/login.do`,data)
   .then(res=>{
       Console.log(res);
})

因為http://106.15.179.92已經(jīng)被代理到/api上!

2.然后配置”package.json”文件

"scripts": {
 "ng": "ng",
 "start": "ng serve --proxy-config proxy.config.json",
 "build": "ng build --prod --aot",
 "test": "ng test",
 "lint": "ng lint",
 "e2e": "ng e2e"
}

4.甩鍋解決跨域

跨域?和我們前端有關(guān)系?有嗎?沒有吧!我不解決,我就不解決,你們后端去解決!

現(xiàn)在介紹一種對于任何項目都通用的解決跨域的方法!

用nginx反向代理實現(xiàn)跨域,是最簡單的跨域方式。只需要修改nginx的配置即可解決跨域問題,支持所有瀏覽器,支持session,不需要修改任何代碼,并且不會影響服務(wù)器性能。

我們只需要配置nginx,在一個服務(wù)器上配置多個前綴來轉(zhuǎn)發(fā)http/https請求到多個真實的服務(wù)器即可。這樣,這個服務(wù)器上所有url都是相同的域名、協(xié)議和端口。因此,對于瀏覽器來說,這些url都是同源的,沒有跨域限制。而實際上,這些url實際上由物理服務(wù)器提供服務(wù)。這些服務(wù)器內(nèi)的javascript可以跨域調(diào)用所有這些服務(wù)器上的url。

下面,給出一個nginx支持跨域的例子,進(jìn)行具體說明。

如,我們有兩個pythonflask開發(fā)的項目:testFlask1和testFlask2。

testFlask2項目上的javascript腳本要通過ajax方式調(diào)用testFlask1的一個url,獲取一些數(shù)據(jù)。

正常情況下部署,就會有跨域問題,瀏覽器拒絕執(zhí)行如下這樣的調(diào)用。

$("button").click(function () {
  $.get("127.0.0.1:8081/partners/json", function (result) {
    $("div").html(result);
  });
});

下面把testFlask2項目的javascrip文件修改一下。這樣訪問同源的url,就不會有跨域問題。

$("button").click(function () {
  $.get("partners/json", function (result) {
    $("div").html(result);
  });
});

但是,我們testFlask2項目實際上沒有partners/json這樣的url,那怎么處理呢?

我們這樣編寫nginx的配置文件:

server{
 listen8000;
 location/ {
  includeuwsgi_params;
  uwsgi_passunix:/tmp/testFlask2.sock;
 }
 location/partners {
  rewrite^.+partners/?(.*)$ /$1 break;
  includeuwsgi_params;
  uwsgi_passunix:/tmp/testFlask1.sock;
 }
}

我們把testFlask2項目部署在8080端口的根目錄下。把提供web服務(wù)的testFlask1項目部署在/partners目錄下。

但我們的testFlask1項目并不能處理/partners/json這樣的url請求。那怎么辦呢?

通過rewrite^.+partners/?(.)$ /$1 break; 這一條命令,nginx可以把收到的/partners/請求全部轉(zhuǎn)為/*請求后再轉(zhuǎn)發(fā)給背后的真實web服務(wù)器。

這樣,RESTFUL的ajax客戶端程序,只需要給出特定前綴的url就可以調(diào)用任意服務(wù)器提供的RESTFUL接口了。

甚至,通過nginx的反向代理,我們還能調(diào)用其他公司開發(fā)的網(wǎng)站提供的RESTFUL接口。

如,

location/sohu {
 rewrite^.+sohu/?(.*)$ /$1 break;
 includeuwsgi_params;
 proxy_passhttp://www.sohu.com/;
}

我們就把sohu網(wǎng)站整個搬到我們的8080:/sohu/目錄下了,我們的javascript就可以盡情調(diào)用其RESTFUL服務(wù)了。

順便說一下,rewrite^.+sohu/?(.)$ /$1 break; 這句命令中,$1表示(.)這個部分。第一對()內(nèi)的參數(shù)是$1,第二對()內(nèi)的參數(shù)就是$2,以此類推。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Angular4如何開發(fā)解決跨域問題”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁題目:Angular4如何開發(fā)解決跨域問題-創(chuàng)新互聯(lián)
URL分享:http://aaarwkj.com/article6/dsppog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、虛擬主機(jī)ChatGPT、電子商務(wù)、移動網(wǎng)站建設(shè)網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
亚洲不卡高清一区二区三区| 青青草原一区二区三区| 国产三级黄色大片在线免费看| 亚洲欧美综合精品久久成人| 后入视频国产在线观看| 巴西老熟女大奶子多毛逼| 亚洲精品日韩国产av| 欧美日韩另类综合久久久| 国产女同一区二区三区久久| 真做的欧美三级在线观看| 亚洲男人天堂日本一区| 天堂av免费资源在线观看| 不卡的av中文字幕在线播放| 欧美性生活在线视频观看| 日本一区二区三区免费不卡视频| 日本一二不卡高清在线视频| 中文字幕伦理一区二区三区| 91麻豆粉色视频在线| 亚洲精品国产熟女高潮| 黄色三级亚洲男人的天堂| 亚洲av成人一区二区三区| 亚洲欧美日韩综合久久| 亚洲国产精品自拍第一页| 国产精品乱码精品久久久| 国产一区免费二区三区四区| 日韩精品欧美视频久久| 日本加勒比不卡在线视频| 成人精品欧美欧美一级乱黄| 久久精品国产av极品| 99久久免费精品老色| 精品欧美激情精品一区| 欧美亚洲国产精品久久久| 男女在线视频网站免费| 亚洲三级成人一区在线| 久草热不卡的av在线| 国产三级黄色大片在线免费看| 亚洲欧美中文日韩二区一区| 国内一级片内射视频播放| 亚洲熟妇精品一区二区三区| 日本区一区二区三啪啪| 国语对白视频在线观看|