vue-cli本地環境API代理設置和解決跨域


前言

我們在使用vue-cli啟動項目的時候npm run dev便可以啟動我們的項目了,通常我們的請求地址是以localhost:8080來請求接口數據的,localhost是沒有辦法設置cookie的。

我們可以在vue-cli配置文件里面設置一個代理,跨域的方法有很多,通常需要后台來進行配置。我們可以直接通過node.js代理服務器來實現跨域請求。

vue proxyTable接口跨域請求調試

在vue-cli項目中的config文件夾下的index.js配置文件中,dev長這樣子:

dev: { 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中新建一個文件命名為proxyConfig.js :

module.exports = { proxy: { '/apis': { //將www.exaple.com印射為/apis target: 'https://www.exaple.com', // 接口域名 secure: false, // 如果是https接口,需要配置這個參數 changeOrigin: true, //是否跨域 pathRewrite: { '^/apis': '' //需要rewrite的, } } } } 

如果本身的接口地址就有 '/api' 這種通用前綴,也就是說https://www.exaple.com/api,就可以把 pathRewrite 刪掉。

config文件夾下的index.js引入proxyConfig.js

var proxyConfig = require('./proxyConfig') 

config文件夾下的index.js中的dev改成:

dev: { env: require('./dev.env'), port: 8080, autoOpenBrowser: true, assetsSubDirectory: 'static', assetsPublicPath: '/', proxyTable: proxyConfig.proxy, cssSourceMap: false } 

重啟項目npm run dev

你會發現出現了這個

圖片描述

這個時候我們已經設置好了本地API代理了

修改本地hosts文件

window文件路徑一般是C:\Window\System32\drivers\etcmac則直接前往文件夾/etc/hosts,打開hosts文件,在這一段下面把localhost設置進去

# localhost name resolution is handled within DNS itself. # 127.0.0.1 localhost # ::1 localhost 127.0.0.1 activate.adobe.com 127.0.0.1 practivate.adobe.com 127.0.0.1 lmlicenses.wip4.adobe.com 127.0.0.1 lm.licenses.adobe.com 127.0.0.1 na1r.services.adobe.com 127.0.0.1 hlrcv.stage.adobe.com localhost www.exaple.com 

搞定

此時我們已經完全解決了跨域問題,以及本地測試后台無法向我們本地環境設置cookie的情況了。

補充

這個文章發布很久了,很多人私信我問我開發地址是什么,上線地址是什么。

在這里進行一下補充,教大家一個一勞永逸的方法;

寫一個config.js文件,作為項目地址的配置。

如下:

//項目域名地址 const url = 'https://exaple.com'; let ROOT; //由於封裝的axios請求中,會將ROOT打包進去,為了方便之后不再更改,判斷了當前環境,而生成的不同的ROOT if (process.env.NODE_ENV === 'development') { //開發環境下的代理地址,解決本地跨域跨域,配置在config目錄下的index.js dev.proxyTable中 ROOT = "/apis" } else { //生產環境下的地址 ROOT = url; } exports.PROXYROOT = url; //代理指向地址 exports.ROOT = ROOT;

這里暴露出去了兩個接口,一個作為代理指向地址,也就是真正的請求地址,一個則為我們的ajax請求的地址。

我們將ROOT引入我們配置的ajax中,再將proxyConfig.js修改如下:

const config = require("../src/fetch/config"); //路徑你們改下 module.exports = { proxy: { [config.ROOT]: { //將www.exaple.com印射為/apis target: config.PROXYROOT,, // 接口域名 secure: false, // 如果是https接口,需要配置這個參數 changeOrigin: true, //是否跨域 pathRewrite: { [`^${config.ROOT}`]: '' //需要rewrite的 } } } }

之后不管是生產環境,還是開發環境,都不用再修改我們的請求地址了。

寫的比較潦草,沒有整理思路,總結一下。

也就是說,之前我們的方法,在npm run dev的時候,ajax請求接口地址需要帶上/apis,而如果我們在npm run build的時候,則需要將ajax接口地址改為真正的地址www.exaple.com,這樣極其不方便,每次都要改。那我們便通過process.env.NODE_ENV來判斷環境,從而導出不一樣的接口。

好了,如果有小伙伴不太清楚的,私信我我重新整理一下當前教程,如果都能看懂我補充的,就不改啦哈哈😄。

 

判斷生產環境還是開發環境方法:

理解webpack之process.env.NODE_ENV詳解(十八)

在node中,有全局變量process表示的是當前的node進程。process.env包含着關於系統環境的信息。但是process.env中並不存在NODE_ENV這個東西。NODE_ENV是用戶一個自定義的變量,在webpack中它的用途是判斷生產環境或開發環境的依據的。

為了查看 process的基本信息,我們可以在文件夾中 新建一個 process.js 文件,在里面加一句代碼:console.log(process);然后進入該文件夾,執行 node process.js 可以在命令行中打印如下信息:

復制代碼
$ node process.js
process {
  title: 'node',
  version: 'v4.4.4',
  moduleLoadList: 
   [....],
  versions: 
   { http_parser: '2.5.2',
     node: '4.4.4',
     v8: '4.5.103.35',
     uv: '1.8.0',
     zlib: '1.2.8',
     ares: '1.10.1-DEV',
     icu: '56.1',
     modules: '46',
     openssl: '1.0.2h' },
  arch: 'x64',
  platform: 'darwin',
  release: 
   { name: 'node',
     lts: 'Argon',
     sourceUrl: 'https://nodejs.org/download/release/v4.4.4/node-v4.4.4.tar.gz',
     headersUrl: 'https://nodejs.org/download/release/v4.4.4/node-v4.4.4-headers.tar.gz' },
  argv: 
   [ '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node',
     '/Users/tugenhua/個人demo/process.js' ],
  execArgv: [],
  env: 
   { TERM_PROGRAM: 'Apple_Terminal',
     SHELL: '/bin/zsh',
     TERM: 'xterm-256color',
     TMPDIR: '/var/folders/l7/zndlx1qs05v29pjhvkgpmhjm0000gn/T/',
     Apple_PubSub_Socket_Render: '/private/tmp/com.apple.launchd.7Ax4C1EWMx/Render',
     TERM_PROGRAM_VERSION: '404',
     TERM_SESSION_ID: '82E05668-442D-4180-ADA3-8CF64D85E5A9',
     USER: 'tugenhua',
     SSH_AUTH_SOCK: '/private/tmp/com.apple.launchd.MYOMheYcL3/Listeners',
     PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin',
     PWD: '/Users/tugenhua/個人demo',
     LANG: 'zh_CN.UTF-8',
     XPC_FLAGS: '0x0',
     XPC_SERVICE_NAME: '0',
     SHLVL: '1',
     HOME: '/Users/tugenhua',
     LOGNAME: 'tugenhua',
     SECURITYSESSIONID: '186a8',
     OLDPWD: '/Users/tugenhua/工作文檔/sns_pc',
     ZSH: '/Users/tugenhua/.oh-my-zsh',
     PAGER: 'less',
     LESS: '-R',
     LC_CTYPE: 'zh_CN.UTF-8',
     LSCOLORS: 'Gxfxcxdxbxegedabagacad',
     NVM_DIR: '/Users/tugenhua/.nvm',
     NVM_NODEJS_ORG_MIRROR: 'https://nodejs.org/dist',
     NVM_IOJS_ORG_MIRROR: 'https://iojs.org/dist',
     NVM_RC_VERSION: '',
     MANPATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/share/man:/usr/local/share/man:/usr/share/man:/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/usr/share/man:/Applications/Xcode.app/Contents/Developer/usr/share/man:/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/share/man',
     NVM_PATH: '/Users/tugenhua/.nvm/versions/node/v4.4.4/lib/node',
     NVM_BIN: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin',
     _: '/Users/tugenhua/.nvm/versions/node/v4.4.4/bin/node',
     __CF_USER_TEXT_ENCODING: '0x1F5:0x19:0x34' },
  pid: 14034,
  features: 
   { debug: false,
     uv: true,
     ipv6: true,
     tls_npn: true,
     tls_sni: true,
     tls_ocsp: true,
     tls: true },
  _needImmediateCallback: false,
  config: {},
  nextTick: [Function: nextTick],
  _tickCallback: [Function: _tickCallback],
  _tickDomainCallback: [Function: _tickDomainCallback],
  stdout: [Getter],
  stderr: [Getter],
  stdin: [Getter],
  openStdin: [Function],
  exit: [Function],
  kill: [Function],
  mainModule: 
   Module {
     id: '.',
     exports: {},
     parent: null,
     filename: '/Users/tugenhua/個人demo/process.js',
     loaded: false,
     children: [],
     paths: 
      [ '/Users/tugenhua/個人demo/node_modules',
        '/Users/tugenhua/node_modules',
        '/Users/node_modules',
        '/node_modules' ] } }
復制代碼

如上就可以看到 process是node的全局變量,並且process有env這個屬性,但是沒有NODE_ENV這個屬性。

process.env 屬性返回的是一個包含用戶環境信息的對象,它可以區分開發環境或正式環境的依據,那么我們如何配置環境變量呢?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM