CXF 拦截器将返回内容进行加密

发布于 2021-12-03 01:14:48 字数 2102 浏览 817 评论 1

 目前写了一个后台程序,对外提供接口是用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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

蓝颜夕 2021-12-07 16:17:25

数据量大的时候报错的问题, 您解决了吗?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文