java处理接口返回的json数据步骤 包括重试处理,异常抛出,日志打印,注意事项

前提

返回格式是json字符串。

注:以下示例 为大致处理过程,使用的是伪代码

步骤:

1,http请求方法

用try catch包裹请求。分两次catch, 第一个catch是捕获IOException。第二个是捕获Exception异常,然后抛出非运行时异常。大致如下:

java 复制代码
public string postcommon() throws IOException{
try(){
   result = http.execute();//发起请求
   //其他处理
}catch(IoException e){
throw e;
}catch(IoException e){
    throw new IOException("Http请求处理异常",e)
}
}

2,http重试处理

写个for循环,重试1中的方法3次,每次停顿500毫秒。

注意使用指数退避,防止立即发起请求,造成服务雪崩。还有sleep异常捕获的强制中断线程处理。

java 复制代码
public string post() throws IOException{
final int mex=3;
final long baseDelay=500;
for(int i=1;i<=3;i++){
    try{

       return postcommon();
    
}catch (IOException e){

    if(i==max){
       log.error();
        throw e instanceof IoException? (IOException) e:new IOException("http",e);
}
    long delay=baseDelay*(long)Math.pow(2,i-1);//指数退避,设置不同的延时时间,防止立即重试挤一堆
     long.warn(重新第几次,重试信息等。。)

    try{
    Thread.sleep(delay)
    }catch (InterruptedException ie){
        Thread.currentThread().interrupt();//需要强制中断这个异常
        throw new IOException("线程被中断",ie);
}
    }
}
throw new IOException(http 所有重试都失败)
}

3,处理返回的json字符串

要多段异常捕获,给出不同的异常信息。

区分日志打印异常详情 和 抛出异常简介的区别

3.1 处理http请求抛出的io异常

首先捕获io异常,直接抛出外部服务异常,并异常日志。

注意是抛出自定义的异常给外层,区别日志打印日志详情。抛出的异常说明只要说明是外部服务异常即可,防止敏感信息泄露。

java 复制代码
String result;
try{
    result=http.post()
}catch(IOException e){
    log.error(e)
    throw new 自定义异常(外部服务异常码,外部服务异常)
}

3.2 返回字符串转json

java 复制代码
JSONObject resultObject;
try{
    resultObject = JSONObject.parseObject(result);
}catch(Exception e){
    log.error(请求外部接口返回结果转json异常,原始返回={},e)
    throw new 自定义异常(内部异常,请求外部接口返回结果转json异常)
}

3.3 处理返回体的目标数据 并透传第三方的错误信息。

正常的请求,返回的数据会放在一个data字段中,如果data有值,则请求一定是正常的。

否则,则判断返回码是不是错误码,如是正确的,那就是返回数据就是空。

如果返回码是错误的,那就是抛出这个三方接口的异常信息,并返回。

java 复制代码
JOSNObject data = resultObject.getObject("data");
if(data==null){

log.warn(外部接口返回数据为空,原始返回是={});
if(!Integer.valueOf(成功返回码).equals( resultObject.getInteger(code1))){
    throw new CommonException(外部接口异常,resultObject.getInteger(message));
}
return Collections.empty();

3.4 返回数据转成具体的java实体

到这一步就相当于请求成功了。

java 复制代码
Model model = data.toJava(Model.class);
return model;

4,不对外抛出异常的处理

如果调用外部接口是否异常 都不能影响我们业务主流程处理。

那么只需要在第3步的方法基础上再用try catch包一层,只打印详细的异常日志即可。

复制代码
try{
    handle();
}catch(Exception e){
    log.warn(异常详情,e)
}
 //主业务
...

总结

看着很复杂,很多段的try catch。也确实很复杂。但是很必要,不同的系统对接,一旦有问题,很容易出现责任不明的问题。所以这种需求有必要详细处理。不像我们内部服务,可以模糊处理,因为都是一个人的职责。

总之 不要怕麻烦。

相关推荐
灰子学技术1 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
老毛肚1 小时前
MyBatis体系结构与工作原理 上篇
java·mybatis
风流倜傥唐伯虎2 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
二十雨辰2 小时前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码2 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚2 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂2 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1362 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
fuquxiaoguang2 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
琹箐2 小时前
最大堆和最小堆 实现思路
java·开发语言·算法