如何解决Zend框架ACL首次切换服务器失败
嗨,大家好! 我不是英语母语,所以如果您改正我的句子,我将不胜感激!
为解释我的问题,这是我们的开发环境。
- 语言:PHP7.3.11
- framework:Zend框架v3.3.11
- 服务器:aws ec2×4
- 服务器操作系统:Amazonlinux 2
- 已启用redis,有两个项目,例如a-project / ec2×2(a-ec2)b-project / ec2×2(b-ec2)
- a-ec2和b-ec2之间的唯一区别是源代码,其他设置(例如nginx,php-fpm,redis和DB设置)相同。
如果我缺少一些信息,请告诉我
当我们联合这些项目时,就会发生问题。
登录我们的服务后,zend工作异常。 loginAction位于a-ec2上,我们可以成功登录。 我们将该会话信息保存在redis上,并且可以正常工作。 但是只有在我们第一次将服务器从a-ec2切换到b-ec2时,才会发生zend acl错误。 我们使用isAllowed函数检查特权,以确定用户是否具有足够的特权来访问某些服务。 位于第827行/library/ZendAcl.php的isAllowd函数首次返回false。 然后,我们重新加载页面,isAllowed函数返回true,以便我们可以访问该服务。 详细来说,在第1161行的&_getRules函数周围出现了问题,该函数使用了_getRuleType函数。 在这些过程中,数组之一以某种方式包含“ TYPE_DENY”。 但是当尝试重新加载(ctrl + f5)时,该值将变成“ TYPE_ALLOW”。
这怎么可能? 以及如何解决这个问题?
我们正在尝试找出2周或更长时间的情况... 预先感谢!
[更新] 我们发现用下面的方法编写的此方法不能很好地工作,因此我们无法正确获取$ auth。
$ auth返回“”。
self::$_auth = $auth = Zend_Auth::getInstance()->getStorage()->read();
[更新2]
我们可能会解决此问题,所以我将保留解决方案。
我们使用
Zend_Auth::getInstance()->getStorage()->read()
从会话中获取$ auth。
但是第一次,保存在a-ec2上的会话信息无法在b-ec2上读取。 因此,我们决定在redis使用会话信息,因此我们更改了方法,使$ auth像
require_once 'Zend/Session.php';
Zend_Session::start();
self::$_auth = $auth = Common_Model_Redis::get();
在连接到Redis服务器之前启动会话,并从中获取会话信息! 我希望这也会对您有用!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。