日期:2014-05-17 浏览次数:20477 次
$fn = __FILE__ . 'lock'; if( file_exists($fn) ) exit('拒绝访问'); file_put_contents($fp, ''); ob_start( 'unlock' ); function unlock( $buffer ) { global $fn; unlink($fn); return $buffer; }
------解决方案--------------------
嗯,不能依靠session控制,是可欺诈的。
只能依靠服务端保证唯一打开了,flock文件锁就可以了.
<?php $fp = @fopen("lock.file", "c"); $ret = flock($fp, LOCK_EX | LOCK_NB); if ($ret) { echo "after flock, before sleep" . PHP_EOL; sleep(5); flock($fp, LOCK_UN); } else { echo "can't obtain the file lock" . PHP_EOL; } ?>
------解决方案--------------------
楼主可能是在做管理系统,因为一些管理系统会有特别的要求或者是担心同时插入的问题。
用数据库吧,核心是
IP(或用户ID)和当前打开页面的路径要关联,就像一个联合主键一样。
openUser openPage
1 index.php
2 modules/user/user_list.php
3 modules/user/user_list.php//这是错误的,因为User 1已经打开了“modules/user/user_list.php”页面。
------解决方案--------------------
嗯,我就是担心他想要一个人已经"打开"的情况下,还不让别人"打开".....