解决 Vue 项目 invalid host header 问题(两种方案)


问题出现背景

做微信H5网页时,使用花生壳内网穿透进行调试时,打开网页显示:invalid host header

分析问题

这句话的意思是:无效的Host请求头;

因为在vue在调试时相当于启动了一个服务器以供我们访问(当我们build后,就可以放在我们自己的nginx等服务器)

测试环境下的webpack有一个host检查功能:webpack的devServer中

如果不配置host就无法访问,解决办法有好几种,可以去设置host,比如:

第一种解决方案

设置允许访问的域名

module.exports = {
  //...
  devServer: {
    allowedHosts: [
      'host.com', // 允许访问的域名地址,即花生壳内网穿透的地址
      '.host.com'   // .是二级域名的通配符   
    ],
  },
};

还有一种更简单的解决方案

更简单的解决方案

设置跳过host检查

// vue3 vue.config.js
module.exports = {
    // 跳过检查host
    devServer: { disableHostCheck: true }
}
// 在vue-cli版本为2.x的情况下修改webpack.dev.conf.js中的devServer对象加入disableHostCheck: true
devServer: {
  disableHostCheck: true,
}

不生效?

必须要重启!必须要重启!必须要重启!

image


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM