IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 通用接口报文转换 -> 正文阅读

[开发测试]通用接口报文转换

每次对接第三方接口时候,都需要进行报文转换,把第三方的报文转换成我方接口报文,或者我方接口报文转换为第三方的报文。转换工作比较繁琐,如果可以做成配置化的,就方便了开发,所以写了个demo进行测试了下

首先,设计了表结构:

CREATE TABLE `thirdparty_param` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `pid` int(11) NOT NULL COMMENT '父id',
  `plat_model` varchar(255) NOT NULL COMMENT '平台id',
  `param_name` varchar(255) DEFAULT NULL COMMENT '三方参数名',
  `param_desc` text COMMENT '参数描述',
  `param_type` varchar(255) DEFAULT NULL COMMENT '参数类型',
  `param_data_type` varchar(255) DEFAULT NULL COMMENT '参数数据类型',
  `value_type` varchar(255) DEFAULT NULL COMMENT '取值类型 1默认值 2取入参属性 3其他个性化',
  `value` varchar(255) DEFAULT NULL COMMENT '转换报文参数取值',
  `value_text` text,
  `value_path` varchar(255) DEFAULT NULL,
  `create_time` datetime DEFAULT NULL COMMENT '创建日期',
  `update_time` datetime DEFAULT NULL COMMENT '更新日期',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8;
/**
 * 转换报文对象
 * @param reqObj 转换后对象
 * @param requestObj 转换前入参对象
 * @param platModel 平台名
 * @param pid 父id
 * @return
 */
public JSONObject traverseParams(JSONObject reqObj,JSONObject requestObj, String platModel, int pid) {
    List<ThirdpartyParam> roots = iThirdpartyParamService.getParamsByPlatAndPid(platModel, pid);

    if (!roots.isEmpty()) {
        for (ThirdpartyParam root : roots) {
            List<ThirdpartyParam> roots2 = iThirdpartyParamService.getParamsByPlatAndPid(platModel, root.getId());
            if (!roots2.isEmpty()) {
                JSONObject object = new JSONObject();
                if("array".equals(root.getParamDataType())){
                    //TODO 当前仅仅支持数组个数为1个元素,不支持多个
                    JSONArray array = new JSONArray();
                    array.add(traverseParams(object,requestObj,platModel,root.getId()));
                    reqObj.put(root.getParamName(),array);
                } else{
                    reqObj.put(root.getParamName(),traverseParams(object,requestObj,platModel,root.getId()));
                }
            }else {
                if ("1".equals(root.getValueType())) {//默认值
                    reqObj.put(root.getParamName(), root.getValue());
                } else if ("2".equals(root.getValueType())) {
                    //TODO 取入参属性 个性化转换
                    List<Object> jsonFieldValue = getJsonFieldValue(requestObj, root.getValuePath());
                    if(jsonFieldValue.isEmpty()){
                        reqObj.put(root.getParamName(), null);
                    }else {
                        reqObj.put(root.getParamName(), jsonFieldValue.get(0));
                    }
                } else if ("3".equals(root.getValueType())) {
                    //TODO 其他

                } else {
                    reqObj.put(root.getParamName(), null);
                }
            }
        }
    }
    return reqObj;
}
/**
     * 根据path 路径 获取jsonObject节点的值 如: request.test
     * @param jsonObject
     * @param path
     * @return
     */
public static List<Object> getJsonFieldValue(JSONObject jsonObject, String path) {
        List<String> keyWordList = new ArrayList(Arrays.asList(path.split("\\.")));
        List<Object> list = new ArrayList<>();
        String key = keyWordList.get(0);
        Object object = jsonObject.get(key);
        keyWordList.remove(0);
        if (keyWordList.isEmpty()) {
            if (null != object) {
                list.add(object);
            }
            return list;
        }

        String subPath = StringUtils.join(keyWordList, ".");
        if (object instanceof JSONArray) {
            JSONArray jsonArray = JSONArray.parseArray(JSON.toJSONString(object));
            if (jsonArray.isEmpty()) {
                return new ArrayList<>();
            }
            jsonArray.forEach(e -> list.addAll(getJsonFieldValue(JSON.parseObject(JSON.toJSONString(e)), subPath)));
        }else if(object instanceof JSONObject){
            JSONObject subJsonObject = JSONObject.parseObject(JSON.toJSONString(object));
            list.addAll(getJsonFieldValue(JSON.parseObject(JSON.toJSONString(subJsonObject)), subPath));
        }
        return list;
    }
@Cacheable(cacheNames = "pb:IThirdpartyParamService:getParamsByPlatAndPid", key = "#platModel+#pid")
    @Override
    public List<ThirdpartyParam> getParamsByPlatAndPid(String platModel, int pid) {
        return baseMapper.getParamsByPlatAndPid(platModel,pid);
    }
<select id="getParamsByPlatAndPid" resultType="ThirdpartyParam">
        select * from thirdparty_param where plat_model = #{platModel} and pid = #{pid}
</select>

经过测试,转换是可以正常转换的,但耗时还得再继续优化,当前一个报文转换得1600多ms,显然对于接口时效性是不太满足的。

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:47:46  更:2022-04-09 18:48:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 0:31:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码