如何使用Jhipster生成的代码添加用于注销的审计?

rao*_*997 6 spring audit-logging jhipster

我调试了如何将审计添加到系统中以便成功登录,并发现使用aop调用了CustomAuditEventRepository.auditEventRepository().add(AuditEvent事件).是否有任何文档如何为任何自定义操作添加审核?

rao*_*997 10

我能用以下代码实现上述功能.

  • 创建可以发布审计事件的类.
import org.springframework.boot.actuate.audit.AuditEvent;
import org.springframework.boot.actuate.audit.listener.AuditApplicationEvent;
import org.springframework.context.ApplicationEventPublisher;
import org.springframework.context.ApplicationEventPublisherAware;
import org.springframework.context.annotation.Configuration;

@Configuration
public class AuditEventPublisher implements ApplicationEventPublisherAware  {
    private ApplicationEventPublisher publisher;

    @Override
    public void setApplicationEventPublisher(
            ApplicationEventPublisher publisher) {
        this.publisher = publisher;
    }

    public void publish(AuditEvent event) {
        if (this.publisher != null)
            this.publisher.publishEvent(new AuditApplicationEvent(event));
    }
}
Run Code Online (Sandbox Code Playgroud)
  • 在需要的位置注入AuditEventPublisher,并调用具有审计事件的publish以插入到db
@RestController
@RequestMapping("/api")
public class UserXAuthTokenController {

    @Inject
    private AuditEventPublisher auditPublisher;

.....
.....

    @RequestMapping(value = "/logout",
            method = RequestMethod.POST)
    @Timed
    public void logout(@RequestParam String authToken) {
        String principal = tokenProvider.getUserNameFromToken(authToken);
        AuditEvent event = new AuditEvent(principal, "LOGOUT_START", new HashMap<String, Object>());
        auditPublisher.publish(event);
        SecurityContextHolder.clearContext();
    }

}
Run Code Online (Sandbox Code Playgroud)