鍍金池/ 問答/HTML/ vue-cli 設(shè)置跨域代理 線上地址報404

vue-cli 設(shè)置跨域代理 線上地址報404

  1. vue-cli 設(shè)置跨域代理,本地正常訪問,線上地址報404。這是什么原因?

vue-cli中跨域代理設(shè)置:

module.exports = {
  dev: {
    // Paths
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      '/api': {
        target: 'https://xxx.xxx-xxx.com',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    },

    // Various Dev Server settings
    host: ip(), // can be overwritten by process.env.HOST
    port: 9999, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined
    autoOpenBrowser: false,
    errorOverlay: true,
    notifyOnErrors: true,
    poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions-

    // Use Eslint Loader?
    // If true, your code will be linted during bundling and
    // linting errors and warnings will be shown in the console.
    useEslint: true,
    // If true, eslint errors and warnings will also be shown in the error overlay
    // in the browser.
    showEslintErrorsInOverlay: false,

    /**
     * Source Maps
     */

    // https://webpack.js.org/configuration/devtool/#development
    devtool: 'eval-source-map',

    // If you have problems debugging vue-files in devtools,
    // set this to false - it *may* help
    // https://vue-loader.vuejs.org/en/options.html#cachebusting
    cacheBusting: true,

    // CSS Sourcemaps off by default because relative paths are "buggy"
    // with this option, according to the CSS-Loader README
    // (https://github.com/webpack/css-loader#sourcemaps)
    // In our experience, they generally work as expected,
    // just be aware of this issue when enabling this option.
    cssSourceMap: false,
  },

  build: {
    // Template for index.html
    index: path.resolve(__dirname, '../dist/index.html'),

    // Paths
    assetsRoot: path.resolve(__dirname, '../dist'),
    assetsSubDirectory: 'static',
    assetsPublicPath: './',

    /**
     * Source Maps
     */

    productionSourceMap: true,
    // https://webpack.js.org/configuration/devtool/#production
    devtool: '#source-map',

    // Run the build command with an extra argument to
    // View the bundle analyzer report after build finishes:
    // `npm run build --report`
    // Set to `true` or `false` to always turn it on or off
    bundleAnalyzerReport: process.env.npm_config_report
  }
}

utils.js 文件中的請求地址設(shè)置:

function network (path, flag) {
  if (flag) {
    return `api/${path}`
  }
  return `api/api/${path}`
}

本地請求正常,線上請求會報404 的錯誤,線上報錯圖片:
圖片描述

回答
編輯回答
淺時光

開發(fā)環(huán)境能夠使用代理是因為啟動了開發(fā)服務(wù)器,能夠把請求轉(zhuǎn)發(fā)到接口,
線上是打包成html部署,你的靜態(tài)站點不會轉(zhuǎn)發(fā)請求,線上可以用nginx做下代理

2018年7月8日 07:38
編輯回答
傲嬌范

跨域?直接axios啊

2018年6月17日 06:37
編輯回答
嫑吢丕

這本來就是開發(fā)環(huán)境下的跨域代理,線上環(huán)境又不起作用??梢允褂胣ginx,或者后臺接口設(shè)置cors
clipboard.png

2017年8月23日 22:13