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

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

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

问题

路由刷新会产生404的问题。
在这里插入图片描述

原因

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

解决

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

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);
    }
}

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

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 13:48:01       106 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 13:48:01       116 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 13:48:01       95 阅读
  4. Python语言-面向对象

    2024-07-12 13:48:01       103 阅读

热门阅读

  1. tkinter的iconbitmap默认图标

    2024-07-12 13:48:01       28 阅读
  2. 【SQL】MySQL 的乐观锁和悲观锁

    2024-07-12 13:48:01       26 阅读
  3. 排序列表 原生方法和comparator方法

    2024-07-12 13:48:01       34 阅读
  4. 音频demo:将PCM数据和Speex数据进行相互编解码

    2024-07-12 13:48:01       23 阅读
  5. MySQL(基础篇)

    2024-07-12 13:48:01       26 阅读
  6. ES6 Class(类) 总结(九)

    2024-07-12 13:48:01       26 阅读
  7. DDD架构

    DDD架构

    2024-07-12 13:48:01      29 阅读
  8. Spring Cloud是什么

    2024-07-12 13:48:01       27 阅读