Vue打包文件dist放在SpringBoot项目下运行(正确实现全过程)(下)

在上一篇中,实现了Vue打包文件dist放在SpringBoot项目下运行。

Vue打包文件dist放在SpringBoot项目下运行(正确实现全过程)(上)

问题

路由刷新会产生404的问题。

原因

vue开发的应用,采用的是SPA单页面模式

每一个页面对应一个html文件,当刷新页面的时候,会主动向后端请求对应的html文件,拿到html文件后渲染界面,但是SPA单页面模式只有一个index.html入口文件,后续的界面跳转都是通过js控制路由跳转实现的。

解决

当我们直接输入/login路径时,先将页面重定向到/index.html,然后通过js控制路由实现跳转就可以了。

项目中增加配置

java 复制代码
import org.springframework.boot.web.server.ErrorPage;
import org.springframework.boot.web.server.ErrorPageRegistrar;
import org.springframework.boot.web.server.ErrorPageRegistry;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;

@Component
public class ErrorConfig implements ErrorPageRegistrar {

    @Override
    public void registerErrorPages(ErrorPageRegistry registry) {
        ErrorPage error404Page = new ErrorPage(HttpStatus.NOT_FOUND, "/index.html");
        registry.addErrorPages(error404Page);
    }
}

项目重启后,刷新就可以了。

相关推荐
用户0595401744614 小时前
Redis持久化踩坑实录:这个数据丢失Bug让我排查了6小时
前端·css
用户21366100357214 小时前
VueRouter进阶-动态路由与嵌套路由
前端·vue.js
梯度不陡14 小时前
Signal #17:Agent 开始进入组织系统
前端·javascript
何智超14 小时前
AI 微前端性能优化之旅(上):复盘
前端·vibecoding
许我半盏清茶14 小时前
前端路由:理解 hash 路由和 history 路由原理
前端·react.js
杨运交14 小时前
[041][公共模块]分布式唯一ID生成器设计与实现:一款灵活可扩展的雪花算法框架
spring boot
胡萝卜术14 小时前
从暴力到Z字形消元:力扣240「搜索二维矩阵II」的降维打击之路
前端·javascript·面试
比老马还六14 小时前
Bipes-Blockly项目二次开发/Coze智能体(十)
前端·嵌入式
14 小时前
Vue 3 组件封装与使用:保姆级教程
前端
星辰15 小时前
深入浅出 Android AOA 协议:通信流程与设备切换附着机制解析
前端