AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 927998
Accepted
Michael Altfield
Michael Altfield
Asked: 2018-08-26 12:33:47 +0800 CST2018-08-26 12:33:47 +0800 CST 2018-08-26 12:33:47 +0800 CST

为什么 Phplist 响应 500 内部服务器错误?

  • 772

我刚刚重新安装了 phplist,但是当我尝试在浏览器中访问它时,我得到一个带有状态代码的空页面:"500 Internal Server Error"

我正在运行 CentOS 7,并且 Phplist 正在使用 Php v5.6.33 的 Apache v2.4.6 上提供服务。

我可以在我的 apache 中看到查询access_log,但 error_log 中没有条目。vhost 配置文件和.htaccess文件似乎都正常。

请帮助我调试为什么 phplist 在全新安装后给我一个 500 错误。

apache-2.4
  • 2 2 个回答
  • 751 Views

2 个回答

  • Voted
  1. Best Answer
    Michael Altfield
    2018-08-26T12:45:43+08:002018-08-26T12:45:43+08:00

    在研究了 phplist 代码几个小时后,我通过在我的服务器上安装 libsodium 来解决这个问题。

    首先,我发现——默认情况下——phplist 会禁止将错误写入日志。这在任何地方都没有记录,所以我在他们的文档页面上留下了一个注释,要求他们记录如何重新启用将错误消息写入日志文件(下面的链接)

    因此,为了防止 phplist 抑制日志文件中的错误,您需要更改error_reporting(0)为error_reporting(1) in'lists/admin/init.php'和我在此处描述'lists/admin/index.php'的。

    然后我能够看到文件在 apacheerror_log文件中引发了以下异常,该'lists/admin/inc/random_compat/random.php'文件是random_compatphplist 中包含的库的一部分。

    [Thu Aug 23 00:06:29.560157 2018] [:error] [pid 17617] [client 127.0.0.1:51262] PHP Fatal error:  Uncaught exception 'Exception' with message 'There is no suitable CSPRNG installed on your system' in /var/www/html/phplist.opensourceecology.org/public_html/lists/admin/inc/random_compat/random.php:204\nStack trace:\n#0 /var/www/html/phplist.opensourceecology.org/public_html/lists/admin/defaultconfig.php(3): random_bytes(10)\n#1 /var/www/html/phplist.opensourceecology.org/public_html/lists/admin/index.php(103): require_once('/var/www/html/p...')\n#2 {main}\n  thrown in /var/www/html/phplist.opensourceecology.org/public_html/lists/admin/inc/random_compat/random.php on line 204
    

    维护者的官方回应(参见 github 上 random_compat repo 的 issue #99)是简单地添加'/dev/urandom'到open_basedirin '/etc/php.ini'. 就个人而言,这似乎不是最明智的选择..

    或者,我决定安装 libsodium。在 CentOS 7 中,这意味着只需安装'php-pecl-libsodium'软件包并重新启动 apache 网络服务器。

    yum install php-pecl-libsodium
    httpd -t && service httpd restart
    

    有关此错误的更多信息,请参阅我的文章,标题为fix phplist 500 error due to random_compat。

    • 1
  2. Carlos Chiriboga
    2019-03-20T02:02:15+08:002019-03-20T02:02:15+08:00

    几个月前我遇到了这个错误,我不得不安装 phplist 旧版本。

    我刚刚发现 php 的新版本(在我的情况下,我使用的是 php-5.2,但 centos 7 带有 php-5.4)有一个名为“date.timezone”的新参数(好吧……对我来说是新的)。我的“/etc/php.ini”现在有:

    date.timezone = "美国/瓜亚基尔"

    您可以在以下位置检查有效的时区名称:

    http://php.net/manual/es/timezones.php

    最好的问候和好运!

    • -1

相关问题

  • Apache2 - SSL 不工作

  • Apache <VirtualHost> 标签,如果客户端的 IP = x 则不重定向... 怎么做?

  • 我无法启用我的网站?[关闭]

  • SELinux 阻止 Apache 写入文件

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve