vue项目中webpack-dev-server的open和host0.0.0.0配置冲突

简介: 一个比较老的公司项目,webpack 用的 v3 版本,为了实现localhost、127.0.0.1和本机ip可以同时访问,webpack的devServer里的 host 我们一般会设置成 0.0.0.0,这样本机所有 ipv4 地址都可以实现访问

一个比较老的公司项目,webpack 用的 v3 版本,为了实现localhost、127.0.0.1和本机ip可以同时访问,webpack的devServer里的 host 我们一般会设置成 0.0.0.0,这样本机所有 ipv4 地址都可以实现访问。

比如我们要将本地运行的前端项目,分享给公司的后端、产品、测试...预览效果,如果 host 直接设置的 localhost,运行后打开的地址 http://localhost:8080,直接分享给别人是没法打开的。

为了解决上面局域网共享的问题,我们就需要将前端服务运行在 0.0.0.0,然后将本机的 ipv4 地址如:http://192.168.2.228:8080 分享给别人,同一局域网内的用户就可以直接访问了。

浏览自动打开了http://0.0.0.0:8080

但是当我们设置之后,默认自动打开的浏览器地址和终端输出的运行地址也变成了:http://0.0.0.0:8080,更要命的是这个地址在 windows 上是被当成无效地址没法访问的,mac上是可以直接访问。
1.png

查看 webpack 配置,注意只保留了相关的主要代码:

// webpack.dev.conf.js
'use strict'
const utils = require('./utils')
const webpack = require('webpack')
const config = require('../config')
const merge = require('webpack-merge')
const baseWebpackConfig = require('./webpack.base.conf')
const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
const portfinder = require('portfinder')

const HOST = process.env.HOST
const PORT = process.env.PORT && Number(process.env.PORT)

const devWebpackConfig = merge(baseWebpackConfig, {
   
   
  devServer: {
   
   
    host: HOST || config.dev.host,
    port: PORT || config.dev.port,
    open: config.dev.open,
  }
})

module.exports = new Promise((resolve, reject) => {
   
   
  portfinder.basePort = process.env.PORT || config.dev.port
  portfinder.getPort((err, port) => {
   
   
    if (err) {
   
   
      reject(err)
    } else {
   
   
      // publish the new Port, necessary for e2e tests
      process.env.PORT = port
      // add port to devServer config
      devWebpackConfig.devServer.port = port

      // Add FriendlyErrorsPlugin
      devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({
   
   
        compilationSuccessInfo: {
   
   
          messages: [`Your application is running here: http://${
     
     devWebpackConfig.devServer.host}:${
     
     port}`],
        },
        onErrors: config.dev.notifyOnErrors
        ? utils.createNotifierCallback()
        : undefined
      }))

      resolve(devWebpackConfig)
    }
  })
})

当设置了自动打开浏览器 open 时,打开的地址会直接用我们设置的 host,所以会打开 http://0.0.0.0:8080。首先需要将服务运行的地址和我们浏览器里打开的地址分开设置,服务运行地址我们需要固定成 0.0.0.0,但浏览器里打开的地址我们不需要这个。

第一点我们可以直接通过 scripts 里的命令来设置 --host 参数指定 0.0.0.0,直接在命令行里传递的参数优先级最高,修改 package.json:

{
   
   
  "name": "front-end",
  "version": "1.0.0",
  "description": "客户端",
  "author": "cafehaus",
  "private": true,
  "scripts": {
   
   
    "predev": "yarn",
    "dev": "webpack-dev-server --inline --progress --host 0.0.0.0 --config build/webpack.dev.conf.js",
    "start": "npm run dev",
    "build": "node build/build.js"
  },
}

devServer.public 配置浏览器地址

然后可以通过 devServer.public 配置来设置浏览器要打开的地址,不过只能webpack的v3和v4版本使用,而且这个必须设置完整的 host:port,但是这个地方的port我们又不能写成固定的,因为如果自己设置的端口被占用了,webpack-dev-server实际运行起来会帮我们找一个系统未被占用的端口。
2.png

我们可以借助 portfinder-sync 来查找系统的可用端口,然后设置给 public,大概的代码思路如下:

const config = require('../config')
const portFinderSync = require('portfinder-sync')
const port = portFinderSync.getPort(config.dev.port)

const devServer = {
   
   
  host: 'localhost',
  open: true,
  port,
  public: `localhost:${
     
     port}`,
},

终极解决方案

要获取实际使用的端口,webpack 其实有用到 portfinder 这个包,我们直接在 webpack.dev.conf.js 里改下最后面的配置就可以了,直接在 portfinder 那设置下 devWebpackConfig.devServer.public 就可以了,我们还可以借助 address 来获取本机的 ipv4 地址,用 chalk 来美化输出:

'use strict'
const utils = require('./utils')
const webpack = require('webpack')
const config = require('../config')
const merge = require('webpack-merge')
const baseWebpackConfig = require('./webpack.base.conf')
const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin')
const portfinder = require('portfinder')
const address = require('address')
const chalk = require('chalk')

const HOST = process.env.HOST || config.dev.host || '0.0.0.0' // 服务地址,设置成 0.0.0.0 可以让本机上所有 ipv4 地址访问
const LOCAL_HOST = config.dev.host || 'localhost' // 本地访问地址
const LOCAL_IP = address.ip() // 本地 ip
const PORT = (process.env.PORT && Number(process.env.PORT)) || config.dev.port || 8080 // 端口

const devWebpackConfig = merge(baseWebpackConfig, {
   
   
  devServer: {
   
   
    host: HOST,
    port: PORT,
    open: config.dev.autoOpenBrowser,
  }
})

module.exports = new Promise((resolve, reject) => {
   
   
  portfinder.basePort = PORT
  portfinder.getPort((err, port) => {
   
   
    if (err) {
   
   
      reject(err)
    } else {
   
   
      // publish the new Port, necessary for e2e tests
      process.env.PORT = port
      // add port to devServer config
      devWebpackConfig.devServer.port = port
      devWebpackConfig.devServer.public = `${
     
     LOCAL_HOST}:${
     
     port}`,

      // Add FriendlyErrorsPlugin
      devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({
   
   
        compilationSuccessInfo: {
   
   
          messages: [
            `  App running at:`,
            `  - Local:   ` + chalk.cyan(`http://${
     
     LOCAL_HOST}:${
     
     port}`)
            `  - Network: ` + chalk.cyan(`http://${
     
     LOCAL_IP}:${
     
     port}`)
          ],
        },
        onErrors: config.dev.notifyOnErrors
        ? utils.createNotifierCallback()
        : undefined
      }))

      resolve(devWebpackConfig)
    }
  })
})

3.png

webpack-dev-server 的几个相关配置

devServer.host

配置访问地址,host:主机、服务机,v3 和 v4 版本默认 localhost,v5 版本默认是 0.0.0.0

devServer.port

端口

devServer.public

可以用来设置默认打开浏览器的地址,注意 v3 和 v4 版本才有这个配置,webpack v5 版本已经没有这项配置了

相关文章
|
7天前
|
JSON 数据可视化 数据库
vue3+threejs+koa可视化项目——实现登录注册(第三步)
vue3+threejs+koa可视化项目——实现登录注册(第三步)
28 5
|
7天前
|
数据可视化 前端开发 JavaScript
vue3+threejs可视化项目——引入threejs加载钢铁侠模型(第二步)
vue3+threejs可视化项目——引入threejs加载钢铁侠模型(第二步)
44 3
|
9天前
|
资源调度 JavaScript 前端开发
Vue的路由管理:VueRouter的配置和使用
【4月更文挑战第24天】VueRouter是Vue.js的官方路由管理器,用于在单页面应用中管理URL路径与组件的映射。通过安装并引入VueRouter,设置路由规则和创建router实例,可以实现不同路径下显示不同组件。主要组件包括:`<router-link>`用于创建导航链接,`<router-view>`负责渲染当前路由对应的组件。此外,VueRouter还支持编程式导航和各种高级特性,如嵌套路由、路由参数和守卫,以应对复杂路由场景。
|
7天前
|
JavaScript 数据可视化 算法
vue3+threejs可视化项目——搭建vue3+ts+antd路由布局(第一步)
vue3+threejs可视化项目——搭建vue3+ts+antd路由布局(第一步)
28 6
|
5天前
|
缓存 JavaScript 前端开发
webpack学习笔记--基本配置
webpack学习笔记--基本配置
|
7天前
|
JSON 数据可视化 前端开发
vue3+threejs+koa可视化项目——模型文件上传(第四步)
vue3+threejs+koa可视化项目——模型文件上传(第四步)
15 7
|
7天前
|
JavaScript 安全 前端开发
Vue 项目中的权限管理:让页面也学会说“你无权访问!
Vue 项目中的权限管理:让页面也学会说“你无权访问!
16 3
|
9天前
|
JavaScript 前端开发
构建工具:配置Webpack打包Vue项目
【4月更文挑战第24天】本文介绍了如何配置Webpack来打包Vue项目。首先,Webpack作为模块打包器处理依赖并打包成可执行文件。接着,通过安装Node.js和npm,创建Vue项目,进入项目目录并配置Webpack的入口、输出、加载器和插件。最后,运行构建命令完成打包。理解Webpack基础并按需配置,能优化前端项目构建和开发体验。
|
9天前
|
资源调度 JavaScript Linux
VueCLI:Vue项目脚手架与构建工具技术详解
【4月更文挑战第24天】VueCLI是Vue.js官方的项目脚手架,简化创建与配置,提供丰富的插件系统,支持全生命周期功能,如代码编译、打包部署。它具有易于配置、跨平台支持等优势。通过安装、创建项目、运行及构建命令,开发者能快速搭建Vue应用。VueCLI允许自定义配置(vue.config.js)和安装各类插件,如vue-router、vuex,以适应不同项目需求,提高开发效率。
|
9天前
|
缓存 JavaScript 前端开发
js开发:请解释什么是Webpack,以及它在项目中的作用。
Webpack是开源的JavaScript模块打包器,用于前端项目构建,整合并优化JavaScript、CSS、图片等资源。它实现模块打包、代码分割以提升加载速度,同时进行资源优化和缓存。Webpack的插件机制可扩展功能,支持热更新以加速开发流程。
16 2