Vue实现项目部署到非根目录及解决刷新页面时找不到资源

 更新时间:2024年03月08日 10:11:36   作者:小破孩呦  
这篇文章主要介绍了Vue实现项目部署到非根目录及解决刷新页面时找不到资源问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

背景:

最近做一个项目打包后需要部署在非根目录的文件夹内进行访问

对于这一问题一开始很是头疼,最后查找和询问同事之后得到如下方法:

1、先解决如何配置非根目录访问的方式

如下:

假设打包后的dist文件内容需要部署到非根目录http.xxx.com/test子路径下,解决步骤如下:

  • 修改vue.config.js中的publicPath
module.exports = {
    publicPath: "/test/", //打包后部署在一个子路径上http:xxx/test/
    productionSourceMap: false,
    devServer: {
        // proxy: "http://xxxx.com", //测试或正式环境域名和端口号
    },
};
  • 修改路由router的/index.js
const router = new VueRouter({
  mode: "history",//路由模式
  base: "/test/",//部署的子路径
  routes,
});
 
export default router;
  • 后端需要帮忙配置

Nginx配置:

location ^~/m {
    try_files $uri $uri/  /m/index.html;
}

Apache配置:

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /index.html [L]
</IfModule>

至此配置完成!!!

但是此时vue使用history模式下 部署 tomcat 时刷新页面就会出现404,找不到资源的问题

可以简单理解History模式跟Hash的区别就是URL不带#号,History需要后台配置支持

  • 在URL中浏览器不会把#后边的参数传给服务端,使用Hash模式时后端同学也不需要单独处理,不会返回404页面,但是有时候自动会直接过滤#后边的参数,对应传参来说不够方便。
  • 当使用History时URL中不带#,请求服务器时将整个URL发送给服务端,如果没有进行相关的路由配置处理,服务端会不认识,返回404或空白页面,所有使用History模式需要后台对路由地址进行相应的处理。

2、此时就需要解决在Tomcat上页面刷新找不到资源的问题了

如下:

在 Tomcat 下 webapps→test(test项目文件名)→创建WEB-INF→创建web.xml

web.xml 内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1" metadata-complete="true">
<display-name>Router for Tomcat</display-name>
<error-page>
<error-code>404</error-code>
<location>/index.html</location>
</error-page>
</web-app>

总结

至此两个问题解决完成!!!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue使用jsencrypt实现rsa前端加密的操作代码

    vue使用jsencrypt实现rsa前端加密的操作代码

    这篇文章主要介绍了vue使用jsencrypt实现rsa前端加密,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • Vue解读之响应式原理源码剖析

    Vue解读之响应式原理源码剖析

    Vue 最独特的特性之一,是其非侵入性的响应式系统,下面这篇文章主要给大家介绍了关于Vue响应式原理源码剖析的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-10-10
  • vue项目实现github在线预览功能

    vue项目实现github在线预览功能

    这篇文章主要介绍了vue项目实现github在线预览功能,本文通过提问两个问题带领大家一起学习整个过程,需要的朋友可以参考下
    2018-06-06
  • Vue自定义组件中v-model的使用方法示例

    Vue自定义组件中v-model的使用方法示例

    日常开发中除了直接在input标签上使用v-model指令外,封装的组件也需要v-model,下面这篇文章主要给大家介绍了关于Vue自定义组件中v-model使用的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • vue引入子组件命名不规范错误的解决方案

    vue引入子组件命名不规范错误的解决方案

    这篇文章主要介绍了vue引入子组件命名不规范错误的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • mpvue中配置vuex并持久化到本地Storage图文教程解析

    mpvue中配置vuex并持久化到本地Storage图文教程解析

    这篇文章主要介绍了mpvue中配置vuex并持久化到本地Storage的教程详解,# 配置vuex和在vue中相同,只是mpvue有一个坑,就是不能直接在new Vue的时候传入store。本文分步骤给大家介绍的非常详细,需要的朋友参考下吧
    2018-03-03
  • vue+echarts实现条纹柱状横向图

    vue+echarts实现条纹柱状横向图

    这篇文章主要为大家详细介绍了vue+echarts实现条纹柱状横向图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • axios全局请求参数设置,请求及返回拦截器的方法

    axios全局请求参数设置,请求及返回拦截器的方法

    下面小编就为大家分享一篇axios全局请求参数设置,请求及返回拦截器的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • vue echart的使用详细教程

    vue echart的使用详细教程

    这篇文章主要为大家详细介绍了Vue中引用echarts的超详细教程,文中的示例代码简洁易懂,对我们熟练使用vue有一定的帮助,需要的小伙伴可以参考一下
    2023-09-09
  • Vue2.0 实现歌手列表滚动及右侧快速入口功能

    Vue2.0 实现歌手列表滚动及右侧快速入口功能

    这篇文章主要介绍了Vue2.0实现歌手列表滚动及右侧快速入口功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-08-08

最新评论