我想让我们的旧脚本再次运行。
前言; 我们正在使用来自过世的人的自定义书面/修改过的脚本。 我们不能用别的东西。 该脚本在旧服务器上运行,但服务器实际上已经过时,因此我尝试将所有内容迁移到较新的服务器。 当前(旧)服务器仍在运行CentOS 5.x以及PHP 5.3和MySQL 5.5。 所以它已经很老了。
无论如何,经过几个小时的调整后,我设法让它与MySQL 5.6一起在CentOS 6.x服务器上运行。 这很好。 我可能也会在CentOS 7.x上运行它,这将是一个不同的步骤。 目前主要的问题是脚本拒绝在PHP 5.3以外的任何更高版本上运行。 哎呀,我甚至无法摆脱它在“升级”到PHP 5.4之后向我投掷的第一条错误消息。
据我所知,问题是由一个(非常过时的)PEAR模块引起的: HTTP_Session2有关此PEAR模块的更多信息,请参见此处 。
显示的错误如下:
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:42 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:43 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:43 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:44 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
[Fri May 31 14:05:44 2019] [error] [client 192.168.0.1] PHP Fatal error: Uncaught MDB2 Error: unknown error Code: -1\n thrown in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 187
该代码的完整部分是:
169 /**
170 * Read session data
171 *
172 * @param string $id The Id!
173 *
174 * @return mixed
175 * @throws HTTP_Session2_Exception An exception!?
176 * @todo Get rid off sprintf()
177 */
178 public function read($id)
179 {
180 $query = sprintf("SELECT data FROM %s WHERE id = %s AND expiry >= %d",
181 $this->options['table'],
182 $this->db->quote(md5($id)),
183 time());
184
185 $result = $this->db->queryOne($query);
186 if (MDB2::isError($result)) {
187 throw new HTTP_Session2_Exception($result->getMessage(),
188 $result->getCode());
189 }
190 $this->crc = strlen($result) . crc32($result);
191 return $result;
192 }
第#187行显然导致了错误。
到目前为止我尝试了什么?
请注意,我不是编码专家。 所以我真的尽我所能。 我已经在互联网,论坛和GitHub上搜索了此错误的解决方案或解决方法。 但没有任何运气。
我也尝试删除/注释掉那部分代码,但这会导致新的错误。 例如:
Fatal error: Class HTTP_Session2_Container_MDB2 contains 1 abstract method and must therefore be declared abstract or implement the remaining methods (HTTP_Session2_Container_Interface::read) in /usr/share/pear/HTTP/Session2/Container/MDB2.php on line 55
我也尝试更新所有PEAR模块,但有些模块根本没有任何更新(包括/尤其是HTTP_Session2模块)。
所以我正在寻找一个可行的解决方案或解决方法。 所以我可以在服务器上使用更新的PHP版本。 如果没有,我将使用PHP 5.3。 虽然服务器只能由我们访问,但我宁愿因各种原因更新它。
也许它也可以从所有代码中完全删除HTTP_Session2模块或者一般禁用它? 我不知道这对应用程序是否重要。 我注意到会话被记录了。 但谁知道呢? 如果它仅用于显示当前在线人员或类似人员,那么删除可能是安全的吗?
无论如何,请提前感谢您看一下这个帖子。 如果您需要更多信息或其他任何信息,请告诉我,我会尽量提供尽可能多的信息。
更新
可能我是一个尝试的完全白痴,但我把所有对“HTTP_Session2”的引用到处(在它所在的每个文件中)。 结果; 接口正在加载(第一次在PHP 5.4上),但是...由于某种原因我不能再登录了。 我猜它真的需要它。
网址显然也有所改变,现在显示:
hxxp://domain.com/index.php?view=login&PHPSESSID=
代替:
hxxp://domain.com/index.php?view=start&session=56d1fdf45cf1400e8e75f
所以我想这不会起作用。 谁有不同的想法?