CXF 拦截器将返回内容进行加密
目前写了一个后台程序,对外提供接口是用cxf写 的webservice
安全方面的考虑要对返回数据进行加密
所以用了拦截器机制 继承AbstractPhaseInterceptor<Message>
super(Phase.PRE_STREAM); // 触发点在流关闭之前
主要代码 基本也是网上的
public void handleMessage(Message message) {
OutputStream os = message.getContent(OutputStream.class);
CachedStream cs = new CachedStream();
message.setContent(OutputStream.class, cs);
message.getInterceptorChain().doIntercept(message);
CachedOutputStream csnew = (CachedOutputStream) message.getContent(OutputStream.class);
InputStream in = csnew.getInputStream();
String result = getRetern(IOUtils.toString(in,"UTF-8"));
IOUtils.copy(new ByteArrayInputStream(result.getBytes("UTF-8")), os);
cs.close();
os.flush();
message.setContent(OutputStream.class, os);
}
返回的数据是用的json格式
当数据量小时没问题,但是一旦数据量过大就会报错 出现
Unexpected EOF in prolog
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
数据量大的时候报错的问题, 您解决了吗?