springboot中使用hibernate envers


添加maven配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.5.RELEASE</version>
    </parent>
    <artifactId>springboot-envers</artifactId>
    <name>springboot-envers</name>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-envers</artifactId>
        </dependency>
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
        </dependency>
    </dependencies>

</project>

使用User類作為被審計的對象

@Entity
@Table(name = "user")
@Audited
@JsonIgnoreProperties(value = "hibernateLazyInitializer")
public class User {

    @Id
    @GeneratedValue
    private Long id;
    private String name;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}

添加配置

spring.jpa.hibernate.ddl-auto=create
spring.jpa.properties.org.hibernate.envers.audit_strategy=org.hibernate.envers.strategy.internal.ValidityAuditStrategy
spring.jpa.properties.org.hibernate.envers.audit_strategy_validity_store_revend_timestamp=true
spring.h2.console.enabled=true
spring.h2.console.path=/h2
spring.datasource.url=jdbc:h2:mem:envers
spring.datasource.username=sa
spring.datasource.password=sa
spring.datasource.driverClassName=org.h2.Driver

創建相應的UserRepository

@Repository
public interface UserRepository extends JpaRepository<User, Long> {
}

添加用於增刪改的Controller

@Controller
public class UserController {
    @Autowired
    private UserRepository userRepository;
    private int counter;

    @ResponseBody
    @RequestMapping("/user/add")
    public Object add() {
        User user = new User();
        user.setName("name" + ++counter);
        userRepository.save(user);
        return user;
    }

    @ResponseBody
    @RequestMapping("/user/update/{id}")
    public Object update(@PathVariable Long id) {
        User user = userRepository.getOne(id);
        user.setName("name" + ++counter);
        userRepository.save(user);
        return user;
    }

    @ResponseBody
    @RequestMapping("/user/delete/{id}")
    public Object delete(@PathVariable Long id) {
        User user = userRepository.getOne(id);
        userRepository.delete(user);
        return user;
    }
}

添加啟動類

@SpringBootApplication
public class SpringbootEnversApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringbootEnversApplication.class, args);
    }
}

運行程序后,訪問http://localhost:8080/h2,輸入密碼sa,即可登陸數據庫並查詢數據

由於配置了spring.jpa.hibernate.ddl-auto=create,可以看到系統已經為我們生成了相關的數據表

 

 其中USER是實體類的表,USER_AUD是對應的審計表

依次訪問以下鏈接,增加兩條數據,分別對兩條數據進行更新,再刪除第一條數據

  http://localhost:8080/user/add

  http://localhost:8080/user/add

  http://localhost:8080/user/update/1

  http://localhost:8080/user/update/2

  http://localhost:8080/user/delete/1

在h2頁面查詢USER表

 

可以看到,USER表只有第二條數據更新后的記錄了

而查詢USER_AUD表

 可以看到表中存在5條記錄,分別對應着上面的五次操作

 其中ID是USER表的主鍵,REV是USER_AUD的主鍵,REVTYPE是操作類型,0新增,1更新,2刪除,name則是對應USER的name屬性

hibernate提供了兩種審計策略,分別是

org.hibernate.envers.strategy.internal.DefaultAuditStrategy
org.hibernate.envers.strategy.internal.ValidityAuditStrategy

 如果使用DefaultAuditStrategy,USER_AUD表中不會有REVEND,REVEND_TSTMP兩個字段,只會單純的記錄變更與版本

而使用ValidityAuditStrategy,在新增一條變更記錄時,會更新上一條變更記錄的REVEND,REVEND_TSTMP為當前的版本號以及變更時間

因為ValidityAuditStrategy除了插入新紀錄還要更新舊的記錄,所以插入速度會慢一點,但是因為提供了額外的信息,對於數據查詢,速度則較DefaultAuditStrategy更快一些


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM