最近有个需求,需要将页面的内容生成excel或者word文档,而且每次的修改都需要生成新的版本,同时需要记录每次修改变化的内容。我们会把每次的修改的内容提交赋值给一个java对象,同时存储到数据库一条新数据,对应数据表一行数据记录。有个功能需要每次对比两个任意版本的数据,前端传递两个不同的版本号参数和其他对应的文档id参数,然后后端对应查出来这两行数据,一种方法是,将两条数据,转换成json字符串返回给前端,前端去对比两个字符串的不同的地方,然后高亮对比展示在页面。其实也可以后端去作对比,将变化的内容和两条数据一起返回,这样前端你可以直接按照后端返回的对比内容,去高亮显示两次修改的不同。
现在模拟这种情况,比如是修改一个user的数据,第一次创建时候是1.0.0版本,然后又再次修改了一些字段的内容,提交后,形成一条新纪录,版本1.0.1版本,现在直接创建两个user对象,就当是从数据库中根据一定条件加上版本号限制查出来的两条数据。
JaVers的官网:https://javers.org/
首先,引入需要的基础Maven依赖:
<!-- 阿里JSON解析器 -->
<dependency>
<groupId>com.alibaba.fastjson2</groupId>
<artifactId>fastjson2</artifactId>
<version>2.0.43</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>31.1-jre</version>
</dependency>
然后写个测试方法,模拟这种场景
import com.alibaba.fastjson2.JSONArray;
import lombok.Data;
import org.apache.commons.lang3.StringUtils;
import org.javers.core.Javers;
import org.javers.core.JaversBuilder;
import org.javers.core.diff.Change;
import org.javers.core.diff.Diff;
import java.util.List;
/**
* @author xiaomifeng1010
* @version 1.0
* @date: 2024-10-24 17:04
* @Description
*/
public class DiffCompareTest {
public static void main(String[] args) {
// 模拟从数据库中查出来了两条数据
User user1 = new User();
user1.setName("张三");
user1.setAge(18);
user1.setAddress("北京");
user1.setPhone("123456789");
user1.setEmail("123456789@qq.com");
user1.setPassword("123456789");
user1.setVersion("1.0.0");
User user2 = new User();
user2.setName("李四");
user2.setAge(18);
user2.setAddress("广州");
user2.setPhone("123456789");
user2.setEmail("123456789@qq.com");
user2.setPassword("dfjdgdg");
user2.setVersion("1.0.1");
Javers javers = JaversBuilder.javers().build();
Diff diff = javers.compare(user1, user2);
System.out.println("对比:"+diff);
List<Change> changes = diff.getChanges();
System.out.println("变化:"+changes);
// 转换成json数组字符串
StringBuilder stringBuilder = new StringBuilder();
stringBuilder.append("[");
for (Change change : changes) {
String valueChange = change.toString().replace("ValueChange", "");
stringBuilder.append(valueChange);
System.out.println("每一项的变化:"+change);
}
stringBuilder.append("]");
String jsonArrayStr = stringBuilder.toString();
// 打印转换之后的json数组字符串
System.out.println("json数组:"+jsonArrayStr);
// 或者赋值给一个java对象
if (StringUtils.isNotBlank(jsonArrayStr)) {
JSONArray jsonArray = JSONArray.parseArray(jsonArrayStr);
List<DiffChange> diffChanges = jsonArray.toJavaList(DiffChange.class);
System.out.println("转换后的对象:"+diffChanges);
}
}
}
@Data
class User {
private String name;
private Integer age;
private String address;
private String phone;
private String email;
private String password;
private String version;
}
@Data
class DiffChange{
private String property;
private String left;
private String right;
}
在实际项目中,数据中是从数据中查询出来的,同时也是通过controller中的接口返回给前端的json数据,根据情况,组合java对象,返回给前端就可以了。
这个示例的运行输出内容如下:
非常好用,而且这个javers开源框架还有对应的各种数据库的审计工具;可以在Maven中央仓库中找到: