Springboot+@RestControllerAdvice导致swagger无法访问

系统增加了@RestControllerAdvice异常处理,后来发现所有的JSP页面和swagger都无法访问了,后来发现是配置出错,只需要把多余的配置注释就OK。

#错误配置信息
#如果增加下面的配置,那么所有的页面都会被拦截
# dont't open,because swagger doc is 404
#spring.mvc.throw-exception-if-no-handler-found=true
#spring.web.resources.add-mappings=false

下面是@RestControllerAdvice异常配置教程。

1、增加ExceptionController.java,这个异常只处理@Controller的日志,例如是JSP项目。

package cn.renkai721.exception;


import cn.renkai721.util.MsgUtil;
import cn.renkai721.util.MyConstants;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
/**
 * @ClassName: ExceptionControllerAdvice
 * @Description:
 * @author: renkai721@163.com
 * @date: 2022年06月10日 9:14 下午
 */
@ControllerAdvice
@Slf4j
public class ExceptionController {

    @ResponseBody
    @ExceptionHandler(value = Exception.class)
    public String exceptionHandler(Exception e){
        // 处理全局异常,所有的Controller中不能自己try catch,必须抛出由系统处理
        // 如果需要自己处理的,那么错误日志也需要自己打印或throw出错误消息
        // 获取异常信息,记录日志
        StackTraceElement stackTraceElement = e.getStackTrace()[0];
        String className = stackTraceElement.getClassName();
        String fileName = stackTraceElement.getFileName();
        int lineNumber = stackTraceElement.getLineNumber();
        String methodName = stackTraceElement.getMethodName();

        log.error("类名={},文件名={},行数={},方法名={}", className, fileName, lineNumber, methodName);
        // 这里是自定义的统一返回格
        log.error("Exception={}",e);
        return MsgUtil.outJson(MyConstants.FAILURE);
    }
}

2、增加ExceptionRestController.java,这个异常只处理@RestController的日志,例如是常规的springboot项目或JSP项目中的API REST接口。

package cn.renkai721.exception;


import cn.renkai721.util.MsgUtil;
import cn.renkai721.util.MyConstants;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestControllerAdvice;

/**
 * @ClassName: ExceptionControllerAdvice
 * @Description:
 * @author: renkai721@163.com
 * @date: 2022年06月10日 9:14 下午
 */
@RestControllerAdvice
@Slf4j
public class ExceptionRestController {

    @ResponseBody
    @ExceptionHandler(value = Exception.class)
    public String exceptionHandler(Exception e){
        // 处理全局异常,所有的Controller中不能自己try catch,必须抛出由系统处理
        // 如果需要自己处理的,那么错误日志也需要自己打印或throw出错误消息
        // 获取异常信息,记录日志
        StackTraceElement stackTraceElement = e.getStackTrace()[0];
        String className = stackTraceElement.getClassName();
        String fileName = stackTraceElement.getFileName();
        int lineNumber = stackTraceElement.getLineNumber();
        String methodName = stackTraceElement.getMethodName();

        log.error("类名={},文件名={},行数={},方法名={}", className, fileName, lineNumber, methodName);
        // 这里是自定义的统一返回格
        log.error("Exception={}",e);
        return MsgUtil.outJson(MyConstants.FAILURE);
    }
}

3、写一个接口用于测试。注意,我们所有的异常都统一处理后,Controller中不要再try catch啦,如果要try catch那么自己需要把日志手动log.error("e={}",e),否则控制台输出的日志或后台打印的日志中是无法看到的。测试访问该接口,在服务器的控制台就能看到错误消息了。

@ApiIgnore
@RequestMapping(value = "/testWrong", method = RequestMethod.GET)
@ResponseBody
public String testWrong() {
// 注意,我们所有的异常都统一处理后,Controller中不要再try catch啦,如果要try catch那么自己需要把日志手动log.error("e={}",e),否则控制台输出的日志或后台打印的日志中是无法看到的。
  int i=1/0;
  return MsgUtil.outJsonSuccess();
}

4、logback-spring.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds">
	<property name="CUSTOM_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%thread]%logger -%msg%n"/>
	<include resource="org/springframework/boot/logging/logback/base.xml"/>

	<!-- 控制台设置 -->
	<appender name="consoleAppender" class="ch.qos.logback.core.ConsoleAppender">
		<encoder>
			<pattern>${CUSTOM_LOG_PATTERN}</pattern>
		</encoder>
	</appender>
	<appender name="ROLLING-FILE-INFO" class="ch.qos.logback.core.rolling.RollingFileAppender">
		<file>logs/myproject.log</file>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- daily rollover -->
			<fileNamePattern>logs/myproject.%d{yyyy-MM-dd}.log</fileNamePattern>
			<!-- 保留30天的历史日志 -->
			<maxHistory>30</maxHistory>
		</rollingPolicy>
		<encoder>
			<pattern>${CUSTOM_LOG_PATTERN}</pattern>
		</encoder>
	</appender>
	<appender name="ROLLING-FILE-WARN" class="ch.qos.logback.core.rolling.RollingFileAppender">
		<file>logs/myproject-warn.log</file>
		<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
			<level>WARN</level>
		</filter>
		<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
			<!-- daily rollover -->
			<fileNamePattern>logs/myproject-warn.%d{yyyy-MM-dd}.log</fileNamePattern>
			<!-- 保留30天的历史日志 -->
			<maxHistory>30</maxHistory>
		</rollingPolicy>
		<encoder>
			<pattern>${CUSTOM_LOG_PATTERN}</pattern>
		</encoder>
	</appender>
	<appender name="grpc-log" class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.log.GRPCLogClientAppender">
		<encoder class="ch.qos.logback.core.encoder.LayoutWrappingEncoder">
			<layout class="org.apache.skywalking.apm.toolkit.log.logback.v1.x.mdc.TraceIdMDCPatternLogbackLayout">
				<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level logger_name:%logger{36} - [%thread] - message:%msg%n</pattern>
			</layout>
		</encoder>
	</appender>
    <!-- additivity="false" 解决控制台输出重复日志 -->
	<logger name="cn.renkai721" level="DEBUG" additivity="false">
		<appender-ref ref="ROLLING-FILE-INFO"/>
		<appender-ref ref="ROLLING-FILE-WARN"/>
		<appender-ref ref="consoleAppender"/>
		<appender-ref ref="grpc-log"/>
	</logger>
    <!-- additivity="false" 解决控制台输出重复日志 -->
	<logger name="org.springframework" level="ERROR" additivity="false">
		<appender-ref ref="ROLLING-FILE-INFO"/>
		<appender-ref ref="ROLLING-FILE-WARN"/>
		<appender-ref ref="consoleAppender"/>
		<appender-ref ref="grpc-log"/>
	</logger>
</configuration>

5.pom文件中增加以下依赖


		<dependency>
			<groupId>org.apache.skywalking</groupId>
			<artifactId>apm-toolkit-logback-1.x</artifactId>
			<version>8.7.0</version>
		</dependency>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

renkai721

谢谢您的打赏!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值