SpringBoot配置404跳转页面的两种方式(配置错误页)

1.情景展示

  当请求不存在时,服务器会报404异常,这对于产品用户来说不够友好。

2.原因分析

  可以配置404请求错误页来进行友好的错误提示。 

3.解决方案

  方式一:

  @GetMapping (  "*" )
public String notFound() {
    // 跳转到404页面所在路径
    return "404" ;
}

  这种方式,同样适用于springmvc,所有不存在的请求都会映射到该方法上。

  但是,问题在于如果项目配置了knife4j项目接口文档,对应的请求是:/doc.html,只有在请求该地址时,项目才会运行生成doc.html,不请求就不存在,因为是临时生成的html文件,原本并不存在于项目当中,所以,在生成页面之前,该方法检测到服务器并不存在doc.html,因此跳转到了404.jsp,就这样,永远也访问不到doc.html,我们也就无法使用knife4j了。

  方式二:

  为了解决这个问题,我们就不能再使用方式一了。

  第一步:添加配置类

  /**
 * 错误页
 * @description: ErrorPage(status,path)说明
 * 关于path,既可以重定向具体的html也可以重定向请求地址
 * 如果配置的是404.html一定要建在template/static下面,否则无效。
 * 如果配置的是/404,那就需要在Controller中添加/404请求对应的方法
 * @author: Marydon
 * @date: 2020年08月11日 0011 11:25
 */
@Configuration
public class ErrorConfig   implements ErrorPageRegistrar {
    @Override
    public void registerErrorPages(ErrorPageRegistry registry) {
        ErrorPage[] errorPages =   new ErrorPage[  1 ];
        errorPages[  0 ] =   new ErrorPage(HttpStatus.NOT_FOUND,   "/404.do" );
        registry.addErrorPages(errorPages);
    }
}

  第二步:在控制器中添加/404.do请求

  /**
 * 不存在的请求,跳转到404页面
 * @description: ErrorConfig已经拦截了404请求,然后映射到这个请求上
 * @date: 2020年07月10日 0010 17:10
 * @param:
 * @return: java.lang.String
 */
@GetMapping (  "/404.do" )
public String notFound() {
    // 跳转到404页面:/jsp/404.jsp
    return "404" ;
}  

  需要提醒的是:即将跳转的页面,必须是相对于项目来说的绝对路径。

  上面是因为我配置了响应路径的前缀和后缀,实际是:/jsp/404.jsp。

#配置视图解析器
#路径前缀
spring.mvc.view.prefix=/jsp/
#路径后缀
spring.mvc.view.suffix=.jsp

  2020-12-27

  这里,说一个在idea中的小技巧,要想知道自己配置的文件路径对不对,可以这样:

  按住Ctrl键不松手,鼠标悬浮到要跳转的路径上。

 

  再次点击鼠标,能打开对应页面就说明没有问题。

4.扩展延伸

2022年2月24日09:19:55

第一个问题:如何判断404配置有没有生效?

正常情况下,当我们上面配置完成后,直接就可以通过页面来判断:咱们的404请求配置有没有生效;

但是,既然来到了这里,就说明是:非正常情况,也就是说:我们无法通过上面请求一个不存在的地址来通过页面的反馈,进而判断为什么不生效?

下面说一下:排查404配置是否生效的正确流程。

错误方式:

上面配置错误页的配置类,也就是:ErrorConfig.java;

它的问题在于:我们在这个类打上断点,在debug模式下,在触发404的时候,是无法进入这个类进行断点调试的。

有且只有一次:在springboot类启动的时候,也就是将该配置类加载到spring当中时,才会进入。

所以说,当我们企图通过这个配置类来判断404导致有没有生效,是行不通的(虽然,在springboot启动的时候,已经将其加载进去)。

正确方式:

既然,我们无法通过配置类来判断,那我们只能通过配置404的Controller入手;

要想404请求能够顺利地跳转到错误提示页,需要保证以下几点: 

第一:上图当中的1是404;2是404请求控制层接收路径;也就是说:1和2保持功能性一致。

第二:2和3保持路径一致;这样,spring才能将请求完成转发,控制层才能匹配上这个请求,并且进入到notFund()方法中。

第三:4是跳转页面的路径,这个路径需要确保:真实存在;否则,响应到客户端的结果,将还是404。

在以上工作,确保准确无误后,我们在这个notFound()当中打个断点,然后,从浏览器访问一个不存在的地址,看看请求能不能进到这里:

如果不能进到这里,排查上图当中的1,2,3这三个步骤。

能进到这里,就说明上图当中的1,2,3是没有问题的,ErrorConfig.java也是没有问题的。

剩下,就是要么是上图当中的4,路径没有配对,或者跳转的页面存在问题。

如果问题是由:从controller到页面造成的404,即下图所示:

解决方案,见文末推荐。

2023年5月25日16:48:15

错误页配置

import org.springframework.boot.web.servlet.ErrorPage;
import org.springframework.boot.web.servlet.ErrorPageRegistrar;
import org.springframework.boot.web.servlet.ErrorPageRegistry;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;

/**
 * <p>
 * 全局错误跳转注入
 * </p>
 */
@Configuration
public class ErrorPageConfig implements ErrorPageRegistrar {

    @Override
    public void registerErrorPages(ErrorPageRegistry registry) {
        ErrorPage error400Page = new ErrorPage(HttpStatus.BAD_REQUEST, "/error400Page");
        ErrorPage error401Page = new ErrorPage(HttpStatus.UNAUTHORIZED, "/error401Page");
        ErrorPage error404Page = new ErrorPage(HttpStatus.NOT_FOUND, "/error404Page");
        ErrorPage error500Page = new ErrorPage(HttpStatus.INTERNAL_SERVER_ERROR, "/error500Page");
        registry.addErrorPages(error400Page, error401Page, error404Page, error500Page);
    }
}

 

写在最后

  哪位大佬如若发现文章存在纰漏之处或需要补充更多内容,欢迎留言!!!

 相关推荐:

posted @ 2020-09-02 09:56  Marydon  阅读(9453)  评论(2编辑  收藏  举报