vue本地连接远程后台接口没问题,部署到服务器访问404,路径请求不到

1:正确步骤

da86ee987a69390233bd28949890dfd.jpg

2:这里其实我自阐述一下

image.png

这里最好注释掉

'use strict'
const path = require('path')
const defaultSettings = require('./src/settings.js')

function resolve(dir) {
  return path.join(__dirname, dir)
}

const name = defaultSettings.title || 'vue Element Admin' // page title

// If your port is set to 80,
// use administrator privileges to execute the command line.
// For example, Mac: sudo npm run
// You can change the port by the following method:
// port = 9527 npm run dev OR npm run dev --port = 9527
const port = process.env.port || process.env.npm_config_port || 9527 // dev port

// All configuration item explanations can be find in https://cli.vuejs.org/config/
module.exports = {
  /**
   * You will need to set publicPath if you plan to deploy your site under a sub path,
   * for example GitHub Pages. If you plan to deploy your site to https://foo.github.io/bar/,
   * then publicPath should be set to "/bar/".
   * In most cases please use '/' !!!
   * Detail: https://cli.vuejs.org/config/#publicpath
   */
  publicPath: './',
  outputDir: 'dist',
  assetsDir: 'static',
  lintOnSave: process.env.NODE_ENV === 'development',
  productionSourceMap: false,
  // devServer: {
  //   port: port,
  //   open: true,
  //   overlay: {
  //     warnings: false,
  //     errors: true
  //   },
  //   before: require('./mock/mock-server.js')
  // },

  /* ========================================================================================================================================*/
  // devServer: {
  //   port: port,
  //   open: true,
  //   overlay: {
  //     warnings: false,
  //     errors: true
  //   }
  // 配置后端的接口
  // proxy: {
  //   [process.env.VUE_APP_BASE_API]: {
  //     // target: 'http://127.0.0.1:8088/zs', // 后台地址
  //     target: 'http://47.98.136.208:8088/zs',
  //     // target: 'https://app.zsyq.top/zs',
  //     changeOrigin: true // 配置跨域
  //     // 发送请求时,请求路径重写:将 /api/xxx --> /xxx (去掉/api)
  //     // pathRewrite: {
  //     //   ['^' + process.env.VUE_APP_BASE_API]: '/zs'
  //     // }
  //   }
  // }
  // before: require('./mock/mock-server.js')
  // },
  /* =====================================================================================================================================*/
  configureWebpack: {
    // provide the app's title in webpack's name field, so that
    // it can be accessed in index.html to inject the correct title.
    name: name,
    resolve: {
      alias: {
        '@': resolve('src')
      }
    }
  },
  chainWebpack(config) {
    // it can improve the speed of the first screen, it is recommended to turn on preload
    // it can improve the speed of the first screen, it is recommended to turn on preload
    config.plugin('preload').tap(() => [
      {
        rel: 'preload',
        // to ignore runtime.js
        // https://github.com/vuejs/vue-cli/blob/dev/packages/@vue/cli-service/lib/config/app.js#L171
        fileBlacklist: [/\.map$/, /hot-update\.js$/, /runtime\..*\.js$/],
        include: 'initial'
      }
    ])

    // when there are many pages, it will cause too many meaningless requests
    config.plugins.delete('prefetch')

    // set svg-sprite-loader
    config.module
      .rule('svg')
      .exclude.add(resolve('src/icons'))
      .end()
    config.module
      .rule('icons')
      .test(/\.svg$/)
      .include.add(resolve('src/icons'))
      .end()
      .use('svg-sprite-loader')
      .loader('svg-sprite-loader')
      .options({
        symbolId: 'icon-[name]'
      })
      .end()

    config
      .when(process.env.NODE_ENV !== 'development',
        config => {
          config
            .plugin('ScriptExtHtmlWebpackPlugin')
            .after('html')
            .use('script-ext-html-webpack-plugin', [{
              // `runtime` must same as runtimeChunk name. default is `runtime`
              inline: /runtime\..*\.js$/
            }])
            .end()
          config
            .optimization.splitChunks({
              chunks: 'all',
              cacheGroups: {
                libs: {
                  name: 'chunk-libs',
                  test: /[\\/]node_modules[\\/]/,
                  priority: 10,
                  chunks: 'initial' // only package third parties that are initially dependent
                },
                elementUI: {
                  name: 'chunk-elementUI', // split elementUI into a single package
                  priority: 20, // the weight needs to be larger than libs and app or it will be packaged into libs or app
                  test: /[\\/]node_modules[\\/]_?element-ui(.*)/ // in order to adapt to cnpm
                },
                commons: {
                  name: 'chunk-commons',
                  test: resolve('src/components'), // can customize your rules
                  minChunks: 3, //  minimum common number
                  priority: 5,
                  reuseExistingChunk: true
                }
              }
            })
          // https:// webpack.js.org/configuration/optimization/#optimizationruntimechunk
          config.optimization.runtimeChunk('single')
        }
      )
  }
}

3 .env.product

# just a flag
ENV = 'production'

# base api
VUE_APP_BASE_API = 'https://app.zsyq.top1234/zs'
#或者 iP+port/xxx

到这里应该是没错了,但是小编个人出现了一直打包,但是界面报404错误

59dc0f54845a23c52d747fdd19777f5.jpg

我后台部署用了docker
然后nginx是docker容器里的,所以我也要把代码复制进行
于是我执行了

docker cp /home/web f93:/home/web

没错,就是这个指令害的
第一次容器里没有web文件夹,新建web文件夹,第一次没问题
之后修改,在执行,他在web文件夹里新建了web文件夹
所以每次打包,复制到容器里去,其实改的都不是nginx指的位置


d189ca73d1b4a85b943d45abba5bb86.jpg

应该是执行

docker cp /home/web f93:/home/

最后得知:可以使用docker -v 或者volume进行挂载,关联,不用复制文件到容器里去
最后就是自己对shell的cp的使用不熟练

你可能感兴趣的:(vue本地连接远程后台接口没问题,部署到服务器访问404,路径请求不到)