java request修改uri,spring cloud zuul过滤器修改requestURI 忽略大小写

通过zuul网关处理requestURI可以做很多事情,如对uri的解密,转发,大小写转化等。

这里对URI做一个简单的大小写的转化。

写一个filter实现ZuulFilter:

packagecom.cis.mr.audit.config;importcom.netflix.zuul.ZuulFilter;importcom.netflix.zuul.context.RequestContext;importcom.netflix.zuul.exception.ZuulException;importjavax.servlet.http.HttpServletRequest;importjavax.servlet.http.HttpServletRequestWrapper;import staticorg.springframework.cloud.netflix.zuul.filters.support.FilterConstants.PRE_TYPE;/***@author:hkk

* @date :Created in 2019/7/11 9:45*/

public class CaseInsenistiveFilter extendsZuulFilter {

@OverridepublicString filterType() {returnPRE_TYPE;

}

@Overridepublic intfilterOrder() {return 4;

}

@Overridepublic booleanshouldFilter() {return true;

}

@Overridepublic Object run() throwsZuulException {

RequestContext ctx=RequestContext.getCurrentContext();

HttpServletRequest request=ctx.getRequest();

String requestURI=request.getRequestURI();

HttpServletRequestWrapper requestWrapper= newHttpServletRequestWrapper(request){

@OverridepublicString getRequestURI() {returnrequestURI.toLowerCase();

}

};

ctx.setRequest(requestWrapper);return null;

}

}

注意这里有几点:

1. filterType是PRE_TYPE ,这是zuul定义的常量。可以通过FilterConstants查看。PRE_TYPE如下图,表示在处理转发请求之前的操作。

e818d367ab7430b2d9ab904a1992fcb4.png

2. flterOrder是4,为什么是4,这里要了解zuul几个自带的filter。特别是PreDecorationFilter

e44a154c26742b89633760142ba0b238.png

下面是几个常用filter的order:

/*** Filter Order for {@linkDebugFilter#filterOrder()}.*/

public static final int DEBUG_FILTER_ORDER = 1;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.pre.FormBodyWrapperFilter#filterOrder()}.*/

public static final int FORM_BODY_WRAPPER_FILTER_ORDER = -1;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.pre.PreDecorationFilter}.*/

public static final int PRE_DECORATION_FILTER_ORDER = 5;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.route.RibbonRoutingFilter#filterOrder()}.*/

public static final int RIBBON_ROUTING_FILTER_ORDER = 10;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.post.SendErrorFilter#filterOrder()}.*/

public static final int SEND_ERROR_FILTER_ORDER = 0;/*** Filter Order for {@linkSendForwardFilter#filterOrder()}.*/

public static final int SEND_FORWARD_FILTER_ORDER = 500;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.post.SendResponseFilter#filterOrder()}.*/

public static final int SEND_RESPONSE_FILTER_ORDER = 1000;/*** Filter Order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.route.SimpleHostRoutingFilter#filterOrder()}.*/

public static final int SIMPLE_HOST_ROUTING_FILTER_ORDER = 100;/*** filter order for {@linkServlet30WrapperFilter#filterOrder()}.*/

public static final int SERVLET_30_WRAPPER_FILTER_ORDER = -2;/*** filter order for

* {@linkorg.springframework.cloud.netflix.zuul.filters.pre.ServletDetectionFilter#filterOrder()}.*/

public static final int SERVLET_DETECTION_FILTER_ORDER = -3;

可以看到PreDecorationFilter的order是5,在它之前的filter,我们设置一个getRequestURI的值,就可以实现需求,PreDecorationFilter是zuul很重要的过滤器,推荐大家仔细了解一下。

最后,我们注入这上fitler。

@BeanpublicCaseInsenistiveFilter getCaseFilter() {return newCaseInsenistiveFilter();

}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的自定义过滤器的代码示例: 1. 创建自定义过滤器类 ```java import org.springframework.cloud.gateway.filter.GatewayFilter; import org.springframework.cloud.gateway.filter.GatewayFilterChain; import org.springframework.core.Ordered; import org.springframework.stereotype.Component; import org.springframework.web.server.ServerWebExchange; import reactor.core.publisher.Mono; @Component public class CustomGatewayFilter implements GatewayFilter, Ordered { @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { // 自定义过滤器逻辑 System.out.println("Custom Gateway Filter executed!"); return chain.filter(exchange); } @Override public int getOrder() { return -1; // 设置过滤器执行顺序 } } ``` 2. 创建自定义过滤器工厂类 ```java import org.springframework.cloud.gateway.filter.GatewayFilter; import org.springframework.cloud.gateway.filter.factory.AbstractGatewayFilterFactory; import org.springframework.stereotype.Component; @Component public class CustomGatewayFilterFactory extends AbstractGatewayFilterFactory<CustomGatewayFilterFactory.Config> { public CustomGatewayFilterFactory() { super(Config.class); } @Override public GatewayFilter apply(Config config) { return new CustomGatewayFilter(); } public static class Config { // 可以在这里添加自定义配置项 } } ``` 3. 配置自定义过滤器 在Spring Boot应用程序中的配置文件(如application.yml)中添加以下配置: ```yaml spring: cloud: gateway: routes: - id: my_route uri: http://localhost:8080 predicates: - Path=/foo/** filters: - CustomGatewayFilter ``` 或者在Java代码中使用以下方式配置: ```java @Bean public RouteLocator customRouteLocator(RouteLocatorBuilder builder) { return builder.routes() .route("my_route", r -> r.path("/foo/**") .filters(f -> f.filter(new CustomGatewayFilter())) .uri("http://localhost:8080")) .build(); } ``` 以上代码示例中,我们创建了一个名为“CustomGatewayFilter”的自定义过滤器,该过滤器在执行时会打印一条日志。我们还创建了一个名为“CustomGatewayFilterFactory”的自定义过滤器工厂类,这个工厂类会返回一个自定义过滤器实例。最后,我们在Spring Cloud Gateway的配置中使用了这个自定义过滤器。 希望这个示例对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值