当前位置: 首页 > 后端技术 > Node.js

vue-cli本地环境API代理设置及解决跨域

时间:2023-04-04 00:05:08 Node.js

鍓嶈█褰撴垜浠娇鐢╲ue-cli鍚姩椤圭洰鏃讹紝npmrundev灏卞彲浠ュ惎鍔ㄦ垜浠殑椤圭洰銆傞€氬父鎴戜滑鐨勮姹傚湴鍧€鏄痩ocalhost:8080鏉ヨ姹傛帴鍙f暟鎹紝localhost鏄病鏈夊姙娉曡缃甤ookie鐨勩€傛垜浠彲浠ュ湪vue-cli閰嶇疆鏂囦欢涓缃唬鐞嗐€傝法鍩熺殑鏂规硶鏈夊緢澶氾紝閫氬父闇€瑕佸湪鍚庡彴杩涜閰嶇疆銆傛垜浠彲浠ョ洿鎺ラ€氳繃node.js浠g悊鏈嶅姟鍣ㄥ疄鐜拌法鍩熻姹傘€倂ueproxyTable鎺ュ彛璺ㄥ煙璇锋眰璋冭瘯鍦╲ue-cli椤圭洰鐨刢onfig鏂囦欢澶逛笅鐨刬ndex.js閰嶇疆鏂囦欢涓紝dev鏄繖鏍风殑锛歞ev:{env:require('./dev.env'),port:8080,autoOpenBrowser:true,assetsSubDirectory:'static',assetsPublicPath:'/',proxyTable:{},cssSourceMap:false}濡傛灉鏈嶅姟鍣ㄦ彁渚涚殑鎺ュ彛鏄繖鏍风殑https://www.exaple.com/server_new/login,鎴戜滑鎶婂煙鍚嶆彁鍙栧嚭鏉ワ紝姣斿https://www.exaple.com锛涘湪config涓垱寤轰竴涓悕涓簆roxyConfig.js鐨勬柊鏂囦欢:module.exports={proxy:{'/apis':{//Injectwww.exaple.comas/apistarget:'https://www.exaple.com',//鎺ュ彛鍩熷悕secure:false,//濡傛灉鏄痟ttps鎺ュ彛锛岄渶瑕侀厤缃鍙傛暟changeOrigin:true,//鏄惁璺ㄥ煙pathRewrite:{'^/apis':''//Rewrite闇€瑕侊紝}}}}濡傛灉鎺ュ彛鍦板潃鏈韩鏈変竴涓叕鍏卞墠缂€'/api'锛屽嵆https://www.exaple.com/api锛屽彲浠ヤ娇鐢╬athRewrite鍒犻櫎銆俢onfig鏂囦欢澶逛笅鐨刬ndex.js寮曞叆proxyConfig.js:varproxyConfig=require('./proxyConfig')config鏂囦欢澶逛笅index.js涓殑dev鏀逛负锛歞ev:{env:require('./dev.env'),port:8080,autoOpenBrowser:true,assetsSubDirectory:'static',assetsPublicPath:'/',proxyTable:proxyConfig.proxy,cssSourceMap:false}閲嶅惎椤圭洰npmrundev:浣犱細鍙戠幇杩欐鎴戜滑璁剧疆濂戒簡鏈湴API浠g悊骞朵慨鏀规湰鍦癶osts鏂囦欢锛寃indow鏂囦欢璺緞涓€鑸负C:\Window\System32\drivers\etc锛宮ac鐩存帴杩涘叆鏂囦欢澶?etc/hosts锛屾墦寮€hosts鏂囦欢锛屽湪鍏朵腑璁剧疆localhost鏈妭#localhost鍚嶇О瑙f瀽鍦―NS鏈韩鍐呭鐞嗐€?127.0.0.1localhost#::1localhost127.0.0.1activate.adobe.com127.0.0.1practivate.adobe.com127.0.0.1lmlicenses.wip4.adobe.com127銆?.0.1lm.licenses.adobe.com127.0.0.1na1r.services.adobe.com127.0.0.1hlrcv.stage.adobe.comlocalhostwww.exaple.com澶у姛鍛婃垚鑷虫鎴戜滑宸茬粡瀹屽叏瑙e喅浜嗚法鍩熼棶棰橈紝骞朵笖鏈湴娴嬭瘯鍚庡彴涓嶈兘缁欐垜浠湰鍦扮幆澧冭缃甤ookie杩欑瘒鏂囩珷鍙戣〃濂戒箙浜嗭紝寰堝浜虹淇¢棶鎴戝紑鍙戝湴鍧€鏄粈涔堬紝鍦ㄧ嚎鍦板潃鏄粈涔堛€傝繖閲岃ˉ鍏呮暀澶у涓€涓竴鍔虫案閫哥殑鏂规硶锛涘啓涓€涓猚onfig.js鏂囦欢浣滀负椤圭洰鍦板潃鐨勯厤缃€傚涓嬶細//椤圭洰鍩熷悕鍦板潃consturl='https://exaple.com';letROOT;//Root浼氳灏佽鍦ㄥ皝瑁呯殑axios璇锋眰涓€備负浜嗘柟渚匡紝鍚庨潰灏变笉鏀逛簡锛屽垽鏂綋鍓嶇幆澧冦€傚拰鐢熸垚鐨勪笉鍚孯OOTif(process.env.NODE_ENV==='development'){//寮€鍙戠幆澧冧腑鐨勪唬鐞嗗湴鍧€锛岃В鍐虫湰鍦拌法鍩熷拰璺ㄥ煙锛屽湪index.js涓厤缃甊OOTdev.proxyTableconfig鐩綍涓?"/apis"}else{//鐢熶骇鐜涓殑鍦板潃ROOT=url;}exports.PROXYROOT=url;//浠g悊鎸囧悜鍦板潃exports.ROOT=ROOT;杩欓噷鏆撮湶浜嗕袱涓帴鍙o紝涓€涓綔涓轰唬鐞嗘寚鍚戝湴鍧€锛屼篃灏辨槸鐪熸鐨勮姹傚湴鍧€锛屼竴涓槸鎴戜滑ajax璇锋眰鐨勫湴鍧€銆傛垜浠湪鎴戜滑閰嶇疆鐨刟jax涓紩鍏OOT锛岀劧鍚庝慨鏀筽roxyConfig.js濡備笅锛歝onstconfig=require("../src/fetch/config");//鏇存敼璺緞涓簃odule.exports={proxy:{[config.ROOT]:{//娉ㄥ叆www.exaple.comas/apistarget:config.PROXYROOT,,//鎺ュ彛鍩熷悕secure:false,//濡傛灉鏄痟ttps鎺ュ彛锛岄渶瑕侀厤缃繖涓弬鏁癱hangeOrigin:true,//鏄惁璺ㄥ煙pathRewrite:{[`^${config.ROOT}`]:''//闇€瑕侀噸鍐檥}}}涔嬪悗锛屾棤璁烘槸鐢熶骇鐜杩樻槸寮€鍙戠幆澧冿紝鎴戜滑閮戒笉鍐嶉渶瑕佷慨鏀规垜浠殑璇锋眰鍦板潃銆傛枃绗旀瘮杈冭崏鐜囷紝娌℃湁鏁寸悊鎬濊矾锛岃嚜宸辨€荤粨涓€涓嬨€備篃灏辨槸璇达紝鍦ㄦ垜浠箣鍓嶇殑鏂规硶涓紝npmrundev鏃讹紝ajax璇锋眰鎺ュ彛鍦板潃闇€瑕佸甫涓?apis锛岃€屽鏋滄垜浠湪npmrunbuild涓紝鍒欓渶瑕佸皢ajax鎺ュ彛鍦板潃鏀逛负鐪熷疄鍦板潃www.exaple.com锛岄潪甯镐笉鏂逛究锛屾瘡娆¢兘瑕佹崲銆傜劧鍚庢垜浠€氳繃process.env.NODE_ENV鍒ゆ柇鐜锛屼粠鑰屽鍑轰笉鍚岀殑鎺ュ彛銆傚棷锛屽鏋滄湁涓嶆槸寰堟竻妤氱殑鏈嬪弸绉佷俊鎴戯紝鎴戜細閲嶆柊鏁寸悊涓€涓嬪綋鍓嶇殑鏁欑▼銆傝兘鐪嬫噦鎴戝姞鐨勫氨鍒敼浜嗗搱鍝堭煒勩€?/p>