关于用 apache cxf中对于不是返回200错误的处理 ,获取错误描述文本的方法

现象

我们在使用apache cxf框架的时候遇到了一些问题,一般来说,如果我们用rest client 如果处理的返回是正确的,那么我们可以很轻易的处理,但是如果我们如果返回的请求返回码不是200,这种情况我们在调试时候发现exception对象中并不包含任何error message的文本:



比如类似这个截图的请求(我们用restclient)测试的,这个返回码是400,返回的响应中有error description字段,我们想要获取这个字段的内容,但是我们尝试了很多次,不能直接从exception对象中获取,也就是说没有一个类似的字段或者API 方法可以直接拿到。


我们的尝试(debug)截图如下:



从这里可以非常明显的看出来,这里没有任何一个字段可以直接拿到和我们的description那段文本相应的内容,所以我们的尝试失败了。


新的突破:

我们一位优秀的工程师想出了一个好办法,其实这个内容并不是没有,而是不直接,其实这段内容已经返回了,它的内容是以字节流的形式放在了response.entity字段中,我们可以从上文的截图中看到,这个response.entity对应的内容是一个HttpURLConnection$HttpInputStream的一个内部类的实例,所以我们必须打开这个字节流然后从中去构造我们所需要的内容。


解决方案如下:

在我们的catch()异常处理分支中:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
catch (WebApplicationException e){
   LOGGER.error( "webapplicationexception: " +e.getResponse().getStatus());  //这一行是获取status code
InputStream in = (InputStream) e.getResponse().getEntity(); //这个输入流中包含了所有的文本信息是关于error message的
byte [] buffer;
try {
     buffer=  new  byte [in.available()];
     in length;
     //打开输入流并且读取,最终将其中的内容拼成字符串
     while ((length = in.read(buffer, 0 ,buffer.length)) != - 1 ){
        output=  new  String(buffer, "UTF-8" );
      }
    } catch (IOException ex){
       LOGGER.error(ex.getMessage());
    }
}
...
上面的code中存在一些的隐患,  in.available() 这个方法返回的是该 InputStream 字节流中所有的字节长度, 可是如果该字节流非常大的话(大到超过int范围呢). 所以这种写法不太建议. 


其实建议使用 org.apache.commons.io library中的 IOUtils 工具类, 可以使用 IOUtils.toString(inputStream) 这样代码看起来会更加的简洁清晰. 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值