dubbo~使用自定义RestRequestFilter过滤器
- ServiceInvokeRestFilterd在包 org.apache.dubbo.rpc.protocol.rest.filter中,它的执行顺序是最低的,为Integer的最大值
- 意味着,我们自定义的Filter都会在ServiceInvokeRestFilterd之前执行
dubbo服务提供者与消费者
建立CustomRestRequestFilter
@Activate // 在任何情况下都激活这个filter
// @Activate(group = "provider", value = "cache") //这个就是在group是“provider” value 等于cache
// 下激活
public class CustomRestRequestFilter implements RestRequestFilter {
private final ErrorTypeAwareLogger logger = LoggerFactory.getErrorTypeAwareLogger(this.getClass());
private final List<RestResponseInterceptor> restResponseInterceptors;
public CustomRestRequestFilter(FrameworkModel frameworkModel) {
this.restResponseInterceptors = frameworkModel.getExtensionLoader(RestResponseInterceptor.class)
.getActivateExtensions();
}
public void setContentType(NettyHttpResponse nettyHttpResponse) {
System.out.println("将响应头添加内容");
nettyHttpResponse.addOutputHeaders(RestHeaderEnum.CONTENT_TYPE.getHeader(),
MediaType.APPLICATION_JSON_VALUE.value);
}
public void filter(RestFilterContext restFilterContext) throws Exception {
setContentType(restFilterContext.getResponse());
}
}
注册这个Filter
/resources/META-INF/dubbo/org.apache.dubbo.rpc.protocol.rest.filter.RestRequestFilter文件
- 内容如下
com.xxx.register.exception.filter.CustomRestRequestFilter
添加包扫描路径
- application.properties
dubbo.scan.base-packages=com.xxx.register.exception.filter
程序启动后,你这个CustomRestRequestFilter在进行rest请求时,会被执行。
注意,它是SPI管理的,不需要其它额外的配置,这并不像org.apache.dubbo.rpc.Filter的实现类,还需要通过dubbo.provider.filter来指定和移除。