gpt4 book ai didi

java - 如何在 Neo4j 非托管扩展中进行压缩响应?

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:57:14 24 4
gpt4 key购买 nike

嗨,

我正在尝试在 Neo4j 非托管扩展中进行 gzipped 响应。我找到了这个例子:http://www.codingpedia.org/ama/how-to-compress-responses-in-java-rest-api-with-gzip-and-jersey/

我尝试添加这个 WriterInterceptor:

@Provider
@Compress
public class GZIPWriterInterceptor implements WriterInterceptor {

@Override
public void aroundWriteTo(WriterInterceptorContext context)
throws IOException, WebApplicationException {

MultivaluedMap<String,Object> headers = context.getHeaders();
headers.add("Content-Encoding", "gzip");

final OutputStream outputStream = context.getOutputStream();
context.setOutputStream(new GZIPOutputStream(outputStream));
context.proceed();
}
}

还有这个注解:

@NameBinding
@Retention(RetentionPolicy.RUNTIME)
public @interface Compress {
}

在我的资源中,我是这样使用它的:

@GET
@Path("/users")
@Produces(MediaType.APPLICATION_JSON)
@Compress
public List<User> getUsers() {
return factory.getUserService(graphDb).getUsers();
}

但是 WriterInterceptor 从未被调用,为什么?我怎样才能使我的回复压缩?

我想在我的非托管插件和解决方案中解决这个问题,其中响应在 Neo4j 之外的代理中被 gzip 压缩是不可替代的。

最佳答案

您需要注册一个关心 gzip 压缩的 servlet 过滤器。这可以在 SPIPluginLifecycle 中完成,请参阅此博客文章:http://www.markhneedham.com/blog/2013/07/08/neo4j-unmanaged-extension-creating-gzipped-streamed-responses-with-jetty/

关于java - 如何在 Neo4j 非托管扩展中进行压缩响应?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33212756/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com