刚开始搭建pLog平台的时候,使用的是PHP4,后来转移到正式服务器上之后,发现后台管理页面登录之后,凡是带有admin.php?op=
xxx的页面全部无法进入,提示“Access is forbidden. You must authenticate first
here.”,刚开始以为是在数据库从测试服务器导出、又导入到正式服务器中出了问题(因为还存在一个MYSQL 4.0 ->
4.1的升级),后来放弃了所有已经保存的设定参数,重新从建立数据库开始在正式服务器上安装,问题依旧。翻看源代码很久,才发现问题原来出现在
SESSION数据的读取上,但还是无法确定具体问题。GOOGLE了许久,在台湾的pLog 中文开发论坛的这篇帖子里终于找到了启发。
pLog在目前的设计中没有完全兼容PHP5,因此上述问题的根本原因如下:
1、pLog使用类似 if( phpversion() >= "4.1.0" )的语法检查当前PHP的版本,如果版本低,则从$HTTP_SESSION_VARS中读取全局变量。而PHP5中提倡使用version_compare()来比较PHP的版本,phpversion()返回值是string类型,直接和字符串比较的结果可能会有误。
2、在比较失败的情况下,PHP5的的默认设置又关闭了register_long_arrays,$HTTP_SESSION_VARS也就不存在了,所以SESSION数据无法获取,系统判断用户没有登录。
解决方法:在PHP.INI中设置register_long_arrays = On,重启APACHE,OK了。