博客
关于我
Spring Cloud Gateway 过滤器中直接返回错误结果信息
阅读量:540 次
发布时间:2019-03-09

本文共 2519 字,大约阅读时间需要 8 分钟。

package com.poly.gateway.filter.auth;import com.fasterxml.jackson.databind.ObjectMapper;import com.poly.gateway.common.BusinessException;import lombok.extern.slf4j.Slf4j;import org.apache.commons.lang3.StringUtils;import org.springframework.cloud.gateway.filter.GatewayFilterChain;import org.springframework.cloud.gateway.filter.GlobalFilter;import org.springframework.core.Ordered;import org.springframework.core.io.buffer.DataBuffer;import org.springframework.http.MediaType;import org.springframework.http.server.reactive.ServerHttpResponse;import org.springframework.stereotype.Component;import org.springframework.web.server.ServerWebExchange;import reactor.core.publisher.Flux;import reactor.core.publisher.Mono;/** * 认证过滤器 *  * @author 向振华 * @date 2020/09/16 10:30 */@Slf4j@Componentpublic class AuthFilter implements GlobalFilter, Ordered {    @Override    public int getOrder() {        return 0;    }    @Override    public Mono
filter(ServerWebExchange exchange, GatewayFilterChain chain) { if (authenticate(exchange)) { return chain.filter(exchange); } else { return errorInfo(exchange, "认证不通过", 1); } } private boolean authenticate(ServerWebExchange exchange) { // 进行认证逻辑,返回true表示认证通过 return true; } public static Mono
errorInfo(ServerWebExchange exchange, String message, Integer status) { Map
resultMap = new HashMap<>(); resultMap.put("status", status == null ? 2 : status); resultMap.put("message", StringUtils.isBlank(message) ? "服务异常!" : message); resultMap.put("info", null); resultMap.put("data", null); return Mono.defer(() -> { byte[] bytes; try { bytes = new ObjectMapper().writeValueAsBytes(resultMap); } catch (JsonProcessingException e) { log.error("网关响应异常:", e); throw new BusinessException("信息序列化异常"); } catch (Exception e) { log.error("网关响应异常:", e); throw new BusinessException("写入响应异常"); } ServerHttpResponse response = exchange.getResponse(); response.getHeaders().add("Content-Type", MediaType.APPLICATION_JSON_UTF8.toString()); DataBuffer buffer = response.bufferFactory().wrap(bytes); return response.writeWith(Flux.just(buffer)); }); }}

以上代码经过优化,主要做了以下修改:

  • 删除了不必要的div标签
  • 简化了注释,去掉了重复和冗余的内容
  • 保持了代码的可读性和专业性
  • 符合技术文档的标准写作风格
  • 保持了核心功能的完整性
  • 转载地址:http://eaxiz.baihongyu.com/

    你可能感兴趣的文章
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询数据库所有表的字段信息
    查看>>
    【Java基础】什么是面向对象?
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>