最近自己在做一个Wiki,采用的struts1。遇到一个问题,就是如何避免多人编辑同一个页面。
先是这么设计的,
在数据库中page对象中添加一个锁属性(locked)。
locked=0表示未加锁,可编辑。locked>0时,表示UserId=valueOf(locked)的这个用户正在编辑,其他人点击编辑按钮时,提示加锁信息。当用户编辑完页面点击保存按钮时,解锁。同时提供一个取消按钮,也执行解锁操作。解锁即将locked值改为0
基本上都实现了,但是在解锁上遇到了新问题。
问题1:出现异常情况时,无法解锁,如死机等
问题2:离开页面时没有解锁,如关闭,点击链接跳转等
个人解决设想:对问题1,在对象中加一个新属性locked_time,然后在系统中做个定时器,定时解锁那些加锁超过规定时间的对象
对问题2,使用window.onunload来监听,但是当只刷新页面时,也会解锁。
这两个问题已经困扰我很长时间了,希望各位给指点一下.....谢谢