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

hyNi 发布于 2016/04/07 21:02
阅读 244
收藏 0

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

加载中
0
秋痕
秋痕

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

返回顶部
顶部