关于如何最好地实现基于Java的Web应用程序的文章修订历史并将其保存在AuditLog中的任何想法
*已经具有这种功能,几乎可以像SVN客户端一样,使一个人看到一个版本与另一个版本之间的差异.
这更多的是设计而不是实现问题.
另外:如何将这些更改显示在网页上?
另外:建议的解决方案
Article
--------------------------------
Integer id
String title
String body
List<Tag> tags
AppUser createdBy
Date createdDate
AuditLog
--------------------------------
Integer id
Integer objectId
Operation operation // enum with UPDATE and DELETE. I won't audit an insert
Date createdDate
AppUser createdBy
String class
String revisionXML
String comment
Hibernate Interceptor将拦截
保存过程,并使用Castor XML创建旧对象的XML字符串.
类和id用于获取特定对象的修订版.
google-diff-match-patch将用于创建HTML差异文件
解决方法:
最好的解决方案是使用已经支持版本(例如Apache Jackrabbit)的数据库或存储.
如果这不是一个选择,那么您必须决定要将文章存储在何处.在文件系统上?然后将每篇文章都设为目录,并将修订版本另存为数字(00001、00002等),然后将上一个修订版本的编号放入一个特殊文件(如当前文件)中.然后,您可以快速找出有多少版本(仅查看最新版本)并前进和后退.
如果您使用数据库,则在商品表中添加一个版本号字段,并添加第二个表或一个标志,该表或标志说明当前版本是哪个.您也可以选择max(version),但这些SQL结构往往很难看且令人困惑.将这些信息保存到其他地方要简单得多.
[编辑]要生成差异,请查看以下项目:google-diff-match-patch