美文网首页
追踪后台字段的变化

追踪后台字段的变化

作者: 比萨u | 来源:发表于2017-05-04 11:02 被阅读31次

    需求:前台开发,需要后台给数据,一般开发后台给的是Json格式的字符串,有后台字段变化了 ,没有来得及告诉我们,导致前台bug,这个锅我不背。为了第一时间知道后台个的数据有没有变化,所以就写了一个方法判断字段变化。在出现问题是第一时间解决。

    实现原理:一般我们解析后台数据都会生成一个JavaBean,利用反射将这个JavaBean 里字段名称获取出来,再和后台数据进行比较。如果不一样就输出logr日志。是不是很简单。

    实现代码

       //判断后台字段又没有增加
        public static List getAddFiled(com.alibaba.fastjson.JSONObject json, Class<?> cls) {
            if (BuildConfig.DEBUG) {
                List<String> data = new ArrayList<>();
                try {
                    LogUtils.d("最新字段总数 = " + json.size());
                    Field[] declaredFields = cls.getDeclaredFields();
                    LogUtils.d("之前字段总数 = " + declaredFields.length);
                    Set<Map.Entry<String, Object>> entries = json.entrySet();
                    for (Map.Entry<String, Object> entry : entries) {
                        for (int i = 0; i < declaredFields.length; i++) {
                            Annotation[] declaredAnnotations = declaredFields[i].getDeclaredAnnotations();
                            for (Annotation declaredAnnotation : declaredAnnotations) {
                                Class<? extends Annotation> aClass = declaredAnnotation.annotationType();
                                Field[] declaredFields1 = aClass.getDeclaredFields();
                                for (Field field : declaredFields1) {
                                    String name = field.getName();
                                    LogUtils.d(name);
                                }
                            }
                            if (entry.getKey().equals(declaredFields[i].getName())) {
                                break;
                            }
                            if (i == declaredFields.length - 1) {
                                data.add(entry.getKey());
                                LogUtils.d("新增加字段 = " + entry.getKey());
                            }
                        }
                    }
                } catch (Exception e) {
                    LogUtils.e(e);
                }
    
                return data;
            } else {
                return null;
            }
    
        }
    

    相关文章

      网友评论

          本文标题:追踪后台字段的变化

          本文链接:https://www.haomeiwen.com/subject/oibkbttx.html