摘要:結(jié)語因為公司的前后端項目通常都放在同一臺服務(wù)器,或者不在同一臺服務(wù)器的時候跨域也是靠后端的同志們?nèi)ソ鉀Q的,所以很少在生產(chǎn)環(huán)境中靠前端解決跨域的這項需求。
前言
在使用vue.js開發(fā)前端項目時,再結(jié)合webpack搞起各種依賴、各種插件進(jìn)行開發(fā),無疑給前端開發(fā)帶來了很多便捷,就在解決跨域這個問題上,相信眾多用vue.js的前端同僚們同我一樣嘗到了甜頭,開發(fā)環(huán)境全靠proxyTable一通配置簡直不要太酸爽。還不明所以然的新手們可能還沒搞清我說的是什么,就是下面這幾行配置:
proxyTable: { "/api": { target: "http://113.113.113.113:5000", //假的接口地址哈 changeOrigin: true, pathRewrite: { "^/api": "" } },
我們的跨域竟然就這樣完美的解決了,然后就開始愉快的請求后端的接口啦!!
回到正題具體場景:公司的一個h5項目是部署在客戶端的,但是部署后出現(xiàn)bug了,由于多人協(xié)同開發(fā)且趕進(jìn)度竟然是打包后因為CSS的問題多個頁面布局亂了,但是開發(fā)環(huán)境并沒有問題啊,怎么打完包樣式就亂了?那就打開dist下的index.html看看唄,復(fù)現(xiàn)一下bug,想都不用想,頁面沒數(shù)據(jù)怎么復(fù)現(xiàn),再去造一套假數(shù)據(jù)?作為一個不喜歡這樣折騰的人必然是不想做這種事情的。
就不勞煩后端了,咱自己解決!
nginx還是要會一些些的,自己配置一下,分分鐘解決,哈哈!
server { listen 8082; server_name 127.0.0.1; //咱自己nginx服務(wù)器地址 #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; } location /app-api { rewrite ^.+app-api/?(.*)$ /$1 break; include uwsgi_params; proxy_pass http://113.113.113.113:5001/; //后端接口地址 //關(guān)鍵部分start add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods "GET, POST, OPTIONS"; add_header Access-Control-Allow-Headers "DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization,token"; //關(guān)鍵部分end //以下配置參見nginx配置文檔哈 #Proxy Settings proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Connection close; proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_max_temp_file_size 0; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } }
目的是把后端接口用nginx再代理一遍,咱自己用nginx間接允許一下跨域請求!
start nginx //在nginx目錄啟動服務(wù)
通常我們會做一個統(tǒng)一的管理接口的js文件,如下形式
var BASE_URL = "/api"; var isPro = process.env.NODE_ENV === "production" if(isPro){ BASE_URL= "http://113.113.113.113:5000", //線上或者測試地址 //BASE_URL= "http://127.0.0.1:8020", //nginx代理地址 //當(dāng)我們需要打包后依然能正常調(diào)接口的時候用這個 } const UrlConfig = { getToken:BASE_URL + "某接口" } export default { UrlConfig };
至此,就把打包后接口跨域的問題優(yōu)雅的解決啦。
結(jié)語因為公司的前后端項目通常都放在同一臺服務(wù)器,或者不在同一臺服務(wù)器的時候跨域也是靠后端的同志們?nèi)ソ鉀Q的,所以很少在生產(chǎn)環(huán)境中靠前端解決跨域的這項需求。不過我分享的這個小技巧也只適用于以上類似場景中,歸根結(jié)底還是要在多人協(xié)同開發(fā)的過程中提前規(guī)劃好公共以及個人的編程規(guī)范,盡量保證開發(fā)環(huán)境和生產(chǎn)環(huán)境是一致的,就可以擺脫很多類似的問題。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/40432.html
摘要:五六月份推薦集合查看最新的請點擊集前端最近很火的框架資源定時更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點擊::集web前端最近很火的vue2框架資源;定時更新,歡迎 Star 一下。 蘇...
摘要:五六月份推薦集合查看最新的請點擊集前端最近很火的框架資源定時更新,歡迎一下。蘇幕遮燎沈香宋周邦彥燎沈香,消溽暑。鳥雀呼晴,侵曉窺檐語。葉上初陽乾宿雨,水面清圓,一一風(fēng)荷舉。家住吳門,久作長安旅。五月漁郎相憶否。小楫輕舟,夢入芙蓉浦。 五、六月份推薦集合 查看github最新的Vue weekly;請::點擊::集web前端最近很火的vue2框架資源;定時更新,歡迎 Star 一下。 蘇...
摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過官方文檔的學(xué)習(xí),對的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細(xì)地介紹本人在處理工程文件構(gòu)建的過程對 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過vue官方文檔的學(xué)習(xí),對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎...
摘要:前言是現(xiàn)階段很流行的前端框架,很多人通過官方文檔的學(xué)習(xí),對的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎么更好的管理自己的項目,如何去引入一些框架以及全家桶其他框架的使用,以下將詳細(xì)地介紹本人在處理工程文件構(gòu)建的過程對 前言 vue是現(xiàn)階段很流行的前端框架,很多人通過vue官方文檔的學(xué)習(xí),對vue的使用都有了一定的了解,但再在項目工程化處理的時候,卻發(fā)現(xiàn)不知道改怎...
閱讀 1776·2021-10-27 14:15
閱讀 3835·2021-10-08 10:12
閱讀 1167·2021-09-22 15:55
閱讀 3230·2021-09-22 15:17
閱讀 832·2021-09-02 15:40
閱讀 1748·2019-08-29 18:33
閱讀 1098·2019-08-29 15:22
閱讀 2355·2019-08-29 11:08