網(wǎng)站建設(shè)前期預(yù)算端點(diǎn)seo博客
? ? ? ? 最近有個(gè)需求,需要將頁(yè)面的內(nèi)容生成excel或者word文檔,而且每次的修改都需要生成新的版本,同時(shí)需要記錄每次修改變化的內(nèi)容。我們會(huì)把每次的修改的內(nèi)容提交賦值給一個(gè)java對(duì)象,同時(shí)存儲(chǔ)到數(shù)據(jù)庫(kù)一條新數(shù)據(jù),對(duì)應(yīng)數(shù)據(jù)表一行數(shù)據(jù)記錄。有個(gè)功能需要每次對(duì)比兩個(gè)任意版本的數(shù)據(jù),前端傳遞兩個(gè)不同的版本號(hào)參數(shù)和其他對(duì)應(yīng)的文檔id參數(shù),然后后端對(duì)應(yīng)查出來(lái)這兩行數(shù)據(jù),一種方法是,將兩條數(shù)據(jù),轉(zhuǎn)換成json字符串返回給前端,前端去對(duì)比兩個(gè)字符串的不同的地方,然后高亮對(duì)比展示在頁(yè)面。其實(shí)也可以后端去作對(duì)比,將變化的內(nèi)容和兩條數(shù)據(jù)一起返回,這樣前端你可以直接按照后端返回的對(duì)比內(nèi)容,去高亮顯示兩次修改的不同。
? ? ? ? ? ?現(xiàn)在模擬這種情況,比如是修改一個(gè)user的數(shù)據(jù),第一次創(chuàng)建時(shí)候是1.0.0版本,然后又再次修改了一些字段的內(nèi)容,提交后,形成一條新紀(jì)錄,版本1.0.1版本,現(xiàn)在直接創(chuàng)建兩個(gè)user對(duì)象,就當(dāng)是從數(shù)據(jù)庫(kù)中根據(jù)一定條件加上版本號(hào)限制查出來(lái)的兩條數(shù)據(jù)。
? ? ? ? ?JaVers的官網(wǎng):https://javers.org/
? ? ? ? ?首先,引入需要的基礎(chǔ)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>
然后寫(xiě)個(gè)測(cè)試方法,模擬這種場(chǎng)景
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) {
// 模擬從數(shù)據(jù)庫(kù)中查出來(lái)了兩條數(shù)據(jù)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("對(duì)比:"+diff);List<Change> changes = diff.getChanges();System.out.println("變化:"+changes);// 轉(zhuǎn)換成json數(shù)組字符串StringBuilder stringBuilder = new StringBuilder();stringBuilder.append("[");for (Change change : changes) {String valueChange = change.toString().replace("ValueChange", "");stringBuilder.append(valueChange);System.out.println("每一項(xiàng)的變化:"+change);}stringBuilder.append("]");String jsonArrayStr = stringBuilder.toString();
// 打印轉(zhuǎn)換之后的json數(shù)組字符串System.out.println("json數(shù)組:"+jsonArrayStr);
// 或者賦值給一個(gè)java對(duì)象if (StringUtils.isNotBlank(jsonArrayStr)) {JSONArray jsonArray = JSONArray.parseArray(jsonArrayStr);List<DiffChange> diffChanges = jsonArray.toJavaList(DiffChange.class);System.out.println("轉(zhuǎn)換后的對(duì)象:"+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;
}
?在實(shí)際項(xiàng)目中,數(shù)據(jù)中是從數(shù)據(jù)中查詢出來(lái)的,同時(shí)也是通過(guò)controller中的接口返回給前端的json數(shù)據(jù),根據(jù)情況,組合java對(duì)象,返回給前端就可以了。
這個(gè)示例的運(yùn)行輸出內(nèi)容如下:
非常好用,而且這個(gè)javers開(kāi)源框架還有對(duì)應(yīng)的各種數(shù)據(jù)庫(kù)的審計(jì)工具;可以在Maven中央倉(cāng)庫(kù)中找到:
?