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来指定和移除。

posted @ 2024-06-14 10:53  张占岭  阅读(29)  评论(0编辑  收藏  举报