3

我在 Drupal 中打开了所有错误 (error_reporting(-1)),但由于某种原因,大多数错误不会出现在日志或屏幕上。我可以通过简单地将函数名称更改为其他名称来复制问题,并且我希望看到函数不存在错误,但我只是得到一个白屏。我已经尝试在 Drupal 框架之外复制它,但我不能 - 所以它让我相信这不是我的 PHP 设置(Zend Server/Apache2/PHP/Windows),而是在 Drupal 的某个地方......

有什么想法吗?

4

8 回答 8

4

我知道这可能会迟到,但它帮助了我。大多数时候一个模块会导致 WSOD,我不能只禁用模块来测试它是什么,因为我可能在这个过程中丢失了数据。我所做的是在 module.inc 中编辑这个函数

function module_invoke_all($hook) {
  $args = func_get_args();
  // Remove $hook from the arguments.
  unset($args[0]);
  $return = array();
  foreach (module_implements($hook) as $module) {

        print "Starting loading $module <br />";

        $function = $module . '_' . $hook;
        if (function_exists($function)) {
          $result = call_user_func_array($function, $args);
          if (isset($result) && is_array($result)) {
            $return = array_merge_recursive($return, $result);
          }
          elseif (isset($result)) {
            $return[] = $result;
          }
        }

        print "Finished loading $module <br />";

  }

  return $return;
}

我在上面的代码中添加了这 2 个打印语句,然后刷新页面,没有达到“完成加载 $module”语句的模块是有问题的模块......在我的情况下是开发的。

找到模块后,您可以进入系统表并查找该模块,将其设置为 status = 0 和 bootstrap = 0 或运行查询:

UPDATE system SET status = 0, bootstrap = 0 WHERE name = 'module_name' LIMIT 1

参考:调试 Drupal 白屏死机(WSOD)

于 2014-03-01T12:24:39.313 回答
3

您需要确保display_errors也已启用。

ini_set( 'display_errors', 'on' );
于 2011-03-11T17:14:33.067 回答
2

WSOD 的完整文档

于 2011-03-11T22:07:42.797 回答
1

这可能是stackoverflow上最愚蠢的答案,但是当我从头开始设计一个cakephp网站并且在css中有白色背景和白色字体时,这发生在我身上,并且什么也得不到,没有错误或sql转储。

看看你是否可以在屏幕上选择文本。

于 2011-03-11T17:20:18.210 回答
0

检查php的“error_reporting”设置,也许?我的设置为:

error_reporting = E_ALL & ~E_DEPRECATED

于 2011-03-11T18:34:42.087 回答
0

有时,如果我包含一个具有关闭 php 令牌的文件,我会收到包括 WSOD 在内的奇怪错误。 ?>

我花了很长时间才找到。

于 2011-03-11T22:45:00.080 回答
0

我开始启用/禁用模块以查看何时可以再次看到错误并将其限制为两个关闭错误处理的模块...经过更多调查后,我发现在 nusoap.php 类中错误报告已被关闭,因为某些错误不断显示(其他一些开发人员已将其关闭)...重新打开,升级 nusoap.php,现在一切正常...感谢大家的帮助

于 2011-03-24T09:33:01.970 回答
0

我注意到您的问题已经得到解答,但它可能有助于其他阅读本文的人知道有时 WSOD 可能是由服务器上较旧的不兼容版本的 PHP 引起的。Drupal 7 需要 PHP 5.3,但许多服务器仍在运行 PHP 5.2。这可能会导致没有错误消息的 WSOD。

于 2014-04-14T16:49:36.667 回答