boot 拦截器 preHandle中响应体 json

记录一下:拦截器设置响应内容

 public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String referer = request.getHeader("referer");
//        if (referer.contains("/doc.html")||referer.contains("/swagger-ui.html")){
//            return true;
//        }
        //HandlerMethod=>Controller中标注@RequestMapping的方法
        // 需要配置静态资源不拦截时,添加这块逻辑  => 前后端分离项目
        if (!(handler instanceof HandlerMethod)) {//放行controller接口外的,如静态资源
            return true;
            //这里如果发现没有这个路径就会return true,但不会结束程序而是再次进入if判断,此时的url是一个/error的路径,这个路径不符合if的条件然后执行下面的代码
        }
        // 跨域配置
        if (request.getHeader(HttpHeaders.ORIGIN) != null) {
            response.addHeader("Access-Control-Allow-Origin", "*");
            response.addHeader("Access-Control-Allow-Credentials", "true");
            response.addHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, PUT, HEAD");
            response.addHeader("Access-Control-Allow-Headers", "Content-Type");
            response.addHeader("Access-Control-Max-Age", "3600");
        }
        //这句话的意思,是让浏览器用utf8来解析返回的数据
        response.setContentType(MediaType.APPLICATION_JSON_VALUE);
        //这句话的意思,是告诉servlet用UTF-8转码,而不是用默认的ISO8859
        response.setCharacterEncoding("UTF-8");

        String token = request.getHeader("token");
        if (!validate(token)) {
            //响应体 是json
            JSONObject res = new JSONObject();
            res.put("responsecode", "401");
            res.put("responsename", "请重新登录");
            response.getWriter().print(res.toString());
            return false;
        } else {
            return true;
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Boot 拦截器可以通过返回一个自定义的响应对象来发送通知到前端 Vue 。具实现步骤如下: 1. 自定义一个响应类,用于封装通知信息,例如: ``` public class ResponseData { private Integer code; private String message; // 省略 getter 和 setter 方法 } ``` 2. 在拦截器判断是否需要发送通知,并设置通知信息到响应,例如: ``` @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 判断是否需要发送通知 if (needToSendNotification(request)) { // 设置通知信息到响应 ResponseData responseData = new ResponseData(); responseData.setCode(200); responseData.setMessage("您有新的消息,请注意查收!"); response.setContentType("application/json;charset=UTF-8"); response.getWriter().write(new ObjectMapper().writeValueAsString(responseData)); return false; } return true; } ``` 3. 在 Vue 使用 axios 发送请求,并处理响应的通知信息,例如: ``` axios.interceptors.response.use( response => { // 判断响应状态码是否为 200 if (response.status === 200) { // 解析响应的通知信息 let responseData = response.data; if (responseData.code === 200) { // 显示通知信息 alert(responseData.message); } } return response; }, error => { // 处理错误信息 console.log(error); return Promise.reject(error); } ); ``` 通过以上步骤,就可以在 Spring Boot 拦截器发送通知到前端 Vue 了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值