如何配置spring boot解决前端刷新不会停留在原路径问题?

本文探讨了一个前端刷新跳转问题,问题在于使用SpringBoot的项目中,前端刷新导致总是跳转到特定页面。解决方案是通过配置SpringBoot的WebServerFactoryCustomizer,将404错误页指向index.html,并且修改后端Controller,使所有请求通过'/**'路由先到达index.html,从而保持页面状态。这种方法确保了在history模式下,刷新时前端能正确处理URL。

  最近遇到一个前端刷新跳转问题,问题背景:项目采用velocity模板加载前端js和css,根路由是斜杆“/“,采用history模式,通过index.html文件加载。后端有一个controller接收 ”/”请求,跳转到index.html的ModelAndView。问题现象:不管在哪个页面,每当刷新页面时,总会跳到一个特定的页面。前端说跳转到该特定页面是他们的处理逻辑,要求后端刷新时必须跳往index.html,他们才能接管Url。

  因为涉及到history模式,这个问题是需要前后端配合才能解决。我们项目中没有采用nginx,用了spring boot的2版本,所以在bootstrap类或@Component类或者@Configuration类中加一个@Bean,启动时加载这个配置,让错误页跳往index.html:

    @Bean
    public WebServerFactoryCustomizer<ConfigurableWebServerFactory> webServerFactoryCustomizer(){
        return new WebServerFactoryCustomizer<ConfigurableWebServerFactory>() {
            @Override
            public void customize(ConfigurableWebServerFactory factory) {
                ErrorPage error404Page = new ErrorPage(HttpStatus.NOT_FOUND, "/index.html");
                factory.setErrorPages(error404Page);
            }
        };
    }

  如果是spring boot的1版本,用这种方式:

    @Bean
    public EmbeddedServletContainerCustomizer containerCustomizer() {
        return container -> {
            ErrorPage error404Page = new ErrorPage(HttpStatus.NOT_FOUND, "/index.html");
            container.addErrorPages(error404Page);
        };
    }

  当光配置错误页跳往index.html还不行,前端要求所有path路径都跳往该index.html,所以我又把后端的这个接入“/”的controller改为接入“/**”,通过加通配符的方式,让前端所有请求都先到index.html,再通过index.html把控制权交还给前端,就能实现刷新时停留在原页面,而不是跳往一个特定的页面去了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值