前端vue报net::ERR_FAILED 500 (Internal Server Error)

spring boot的filter抛出的自定义异常,使用自定义controller来捕获。

复制代码
import org.springframework.boot.web.servlet.error.ErrorController;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.RequestMapping;

import javax.servlet.http.HttpServletRequest;

/**
 * 捕获filter抛出的异常交由BusinessExceptionAdvice处理
 * 请求进来 会按照 filter -> interceptor -> controllerAdvice -> aspect -> controller的顺序调用
 * 当controller返回异常 也会按照controller -> aspect -> controllerAdvice -> interceptor -> filter来依次抛出
 *
 * @author dengdxu
 * @Datetime 2024/8/24
 **/
@Controller
public class ErrorControllerImpl implements ErrorController {

    public String getErrorPath() {
        return "/error";
    }

    @RequestMapping("/error")
    public void handleError(HttpServletRequest request) throws Throwable {
        if (request.getAttribute("javax.servlet.error.exception") != null) {
            throw (Throwable) request.getAttribute("javax.servlet.error.exception");
        }
    }
}

其他业务异常正常返回,但是filter异常在前端报跨域异常:No 'Access-Control-Allow-Origin' header is present, net::ERR_FAILED 500 (Internal Server Error)

这是由于自定义的controller没有配置跨域,给ErrorControllerImpl 加上@CrossOrigin注解就可以了

相关推荐
Aliex_git10 分钟前
性能优化 - 构建体积优化
前端·javascript·笔记·学习·性能优化
QT 小鲜肉11 分钟前
【Linux命令大全】003.文档编辑之comm命令(实操篇)
linux·运维·服务器·javascript·chrome·笔记
千里马-horse16 分钟前
Rect Native bridging 源码分析--Array.h
javascript·c++·react native·react.js·bridging
xiaoxue..18 分钟前
React 之 自定义 Hooks
前端·javascript·react.js·面试·前端框架
华仔啊19 分钟前
JavaScript 防抖和节流的区别是什么?如何实现?
前端·javascript
钰衡大师36 分钟前
电商后台管理系统:动态路由刷新空白问题分析与解决方案
vue.js·elementui·前端框架
想唱rap1 小时前
缓冲区的理解和实现
java·服务器·前端·c++·python
勤奋的小米蜂1 小时前
vscode 自带终端无法正常执行例如npm命令---解决办法
前端·vue.js·vscode·npm
你怎么知道我是队长1 小时前
C语言---作用域
c语言·开发语言·javascript
Wpa.wk1 小时前
接口测试-多层嵌套响应处理-JSONPath使用(Java版)
java·前端·经验分享·python·测试工具·jsonpath