2

当变量/属性的类型错误时,我经常遇到问题。问题是很难追踪,因为我的 PHP (5.3) 只是崩溃了,没有发出错误,甚至没有写入错误日志 (*1)。它只是崩溃。

我认为访问像数组这样的字符串不应该是不可追踪的吗?我的意思是,PHP 不是 C 对吗?

有没有办法改变这种行为或某种最佳实践来解决这个问题?除了一直检查每个变量并因此编写 5 倍以上的代码之外?

[更新]:好的,如果我在 Zend 之外简化代码,它似乎可以工作。它一定与 Zend 相关。虽然我确实在我的 application.ini 中设置了所有 phpSettings:

phpSettings.display_startup_errors = 1
phpSettings.display_errors = 1
phpSettings.error_reporting = "E_ALL|E_STRICT"

导致错误的代码(我刚刚尝试在沙箱中工作)是这样的:

$prefix = (strpos($obj[3][1], 'videometa') !== false) ? "http://www7.example.org" : "http://www.example.org";

其中 $obj 是一个 json 字符串。

[更新 2]:所以我尝试使用代码上方的 ini_get 回显 php 设置,它说 error_reporting 在 E_ALL|E_STRICT 上,display_error 为 ON 等。

所以这:

echo '<br/>ini_get = '.ini_get('display_errors').';';
echo '<br/>ini_get = '.ini_get('error_reporting').';';
echo '<br/>ini_get = '.ini_get('error_log').';';
echo '<br>$obj: ';
$obj = 'peter';
var_dump($obj);

echo '<br/>Now for the critical code:';
$prefix = (strpos($obj[MC_IMAGETYPE_VDT][1], 'videometa') !== false) ? "http://www7.example.org" : "http://www.example.org";

echo '<br/>It never shows this!';

发这个:

ini_get = 1;
ini_get = E_ALL|E_STRICT;
ini_get = /Applications/MAMP/logs/php_error.log;
$obj: string(5) "peter"

Now for the critical code:

然后停止。有任何想法吗?

*1。php.ini 有 display_errors = On 和 error_reporting = E_ALL 等等。都好。

4

1 回答 1

3

我不认为您用来设置错误报告的方法是正确的,当它应该是数字时,您将其设置为字符串值(或常量,例如具有数字值的 E_ALL)。试试:

phpSettings.error_reporting = E_ALL|E_STRICT

(即没有引号)或:

phpSettings.error_reporting = 32767

如果一切都失败了,您总是可以暂时将错误报告值设置在您认为导致问题的代码之上:

error_reporting(E_ALL);

另外,你有:

$prefix = (strpos($obj[MC_IMAGETYPE_VDT][1], 'videometa') !== false) ? "http://www7.example.org" : "http://www.example.org";

但是$obj是您尝试作为嵌套数组访问的字符串。这会给你Fatal error: Cannot use string offset as an array这可能是你的代码失败的原因。

于 2011-07-19T11:23:23.303 回答