首页 >后端开发 >php教程 >关于php报错的一个疑问

关于php报错的一个疑问

WBOY
WBOY原创
2016-06-06 20:44:55979浏览

我是用的是phpstudy2014的套件
但是我在部分地方做了修改使其能够同时兼容php5.3和5.2.7版本
修改地方为 vhosts.conf

<code><VirtualHost *:80>
LoadFile "D:/phpStudy/php52/php5ts.dll"
LoadModule php5_module "D:/phpStudy/php52/php5apache2_4.dll"
<IfModule php5_module>
PHPIniDir "D:/phpStudy/php52/"
</IfModule>
LoadFile "D:/phpStudy/php52/libmysql.dll"
LoadFile "D:/phpStudy/php52/libmcrypt.dll"
<FilesMatch "\.php$">
    SetHandler application/x-httpd-php
</FilesMatch>
    DocumentRoot "F:\github\xinyupingtai"
    ServerName d.hainuo.info
    ServerAlias hainuo.info
</VirtualHost>
<Directory "F:\github\xinyupingtai">
    Options FollowSymLinks ExecCGI
    AllowOverride All
    Order allow,deny
    Allow from all
</Directory>
</code>

这个是5.2的配置文件,之前因为使用了

<code class="lang-php">error_reporting(0);
</code>

将所有错误屏蔽掉,但是因为一些原因(后来才发现是我使用了一个未引入的方法)导致程序输出空白,于是我将错误报告改为error_reporting(E_ALL);但是我发现结果令我很崩溃,百度浏览器直接团出错误页,ie11给我的还是空白页。

类的导入原理是

<code class="lang-php">function __autoload($name)
{
    $class_file = d('./class/' . $name . '.php');
    if (file_exists($class_file)) {
        include($class_file);
    } else {
        if (strpos($name, '_') !== false) {
            $name = strtr($name, '_', '.');
            if (!loadLib($name)) {
                //exit('class '.$name.' not include');
                return false;
            }
        } else {
            //exit('class '.$name.' not include');
            return false;
        }
    }
}

function loadLib($libName, $returnClass = false)
{
    global $_libraryLoadLog;
    if (!isset($_libraryLoadLog[$libName])) {
        $libPath = WROOT . 'class' . D . strtr($libName, '.', D) . '.php';
        if (file_exists($libPath)) {
            if (($f = strrpos($libName, '.')) !== false) {
                $libP = substr($libName, 0, $f) . '.'; //library parent
            } else {
                $libP = '';
            }
            include($libPath);
            $_libraryLoadLog[$libName] = strtr($libName, '.', '_');
        } else {
            $_libraryLoadLog[$libName] = '';
        }
    }
    if ($_libraryLoadLog[$libName]) {
        if ($returnClass) {
            $className = $_libraryLoadLog[$libName];
            $class = new $className();
            return $class;
        } else {
            return true;
        }
    }
    return false;
}
</code>

我是用了一个方法是 $dom=file_get_html(url);
此方法是simple_html_dom 类中自带的
simpe html dom类链接 点击可以查看这个类的源代码
当我使用var_dump一点点的测试出原因后才明白原来是我的那个dom类没有导入

把这个问题写在这里,是想问各位大大,
1、遇到这种情况,你们是怎么调试程序的?
2、为什么指定了输出错误,却仍然是空白,即php不报错呢?
3、如果第二条不好回答,可否给解释一下php的报错原理


6.27修改
因为楼下提供的方法并不怎么适用
一气之下我将error_reporting(E_ALL);注释掉,妈呀,竟然报错了

Parse error: syntax error, unexpected '}' in F:*****libdialog.php on line 1018

不过还是感谢各位对我的帮助。

回复内容:

我是用的是phpstudy2014的套件
但是我在部分地方做了修改使其能够同时兼容php5.3和5.2.7版本
修改地方为 vhosts.conf

<code><VirtualHost *:80>
LoadFile "D:/phpStudy/php52/php5ts.dll"
LoadModule php5_module "D:/phpStudy/php52/php5apache2_4.dll"
<IfModule php5_module>
PHPIniDir "D:/phpStudy/php52/"
</IfModule>
LoadFile "D:/phpStudy/php52/libmysql.dll"
LoadFile "D:/phpStudy/php52/libmcrypt.dll"
<FilesMatch "\.php$">
    SetHandler application/x-httpd-php
</FilesMatch>
    DocumentRoot "F:\github\xinyupingtai"
    ServerName d.hainuo.info
    ServerAlias hainuo.info
</VirtualHost>
<Directory "F:\github\xinyupingtai">
    Options FollowSymLinks ExecCGI
    AllowOverride All
    Order allow,deny
    Allow from all
</Directory>
</code>

这个是5.2的配置文件,之前因为使用了

<code class="lang-php">error_reporting(0);
</code>

将所有错误屏蔽掉,但是因为一些原因(后来才发现是我使用了一个未引入的方法)导致程序输出空白,于是我将错误报告改为error_reporting(E_ALL);但是我发现结果令我很崩溃,百度浏览器直接团出错误页,ie11给我的还是空白页。

类的导入原理是

<code class="lang-php">function __autoload($name)
{
    $class_file = d('./class/' . $name . '.php');
    if (file_exists($class_file)) {
        include($class_file);
    } else {
        if (strpos($name, '_') !== false) {
            $name = strtr($name, '_', '.');
            if (!loadLib($name)) {
                //exit('class '.$name.' not include');
                return false;
            }
        } else {
            //exit('class '.$name.' not include');
            return false;
        }
    }
}

function loadLib($libName, $returnClass = false)
{
    global $_libraryLoadLog;
    if (!isset($_libraryLoadLog[$libName])) {
        $libPath = WROOT . 'class' . D . strtr($libName, '.', D) . '.php';
        if (file_exists($libPath)) {
            if (($f = strrpos($libName, '.')) !== false) {
                $libP = substr($libName, 0, $f) . '.'; //library parent
            } else {
                $libP = '';
            }
            include($libPath);
            $_libraryLoadLog[$libName] = strtr($libName, '.', '_');
        } else {
            $_libraryLoadLog[$libName] = '';
        }
    }
    if ($_libraryLoadLog[$libName]) {
        if ($returnClass) {
            $className = $_libraryLoadLog[$libName];
            $class = new $className();
            return $class;
        } else {
            return true;
        }
    }
    return false;
}
</code>

我是用了一个方法是 $dom=file_get_html(url);
此方法是simple_html_dom 类中自带的
simpe html dom类链接 点击可以查看这个类的源代码
当我使用var_dump一点点的测试出原因后才明白原来是我的那个dom类没有导入

把这个问题写在这里,是想问各位大大,
1、遇到这种情况,你们是怎么调试程序的?
2、为什么指定了输出错误,却仍然是空白,即php不报错呢?
3、如果第二条不好回答,可否给解释一下php的报错原理


6.27修改
因为楼下提供的方法并不怎么适用
一气之下我将error_reporting(E_ALL);注释掉,妈呀,竟然报错了

Parse error: syntax error, unexpected '}' in F:*****libdialog.php on line 1018

不过还是感谢各位对我的帮助。

要想让 php 把错误输出到网页,需要把 php.ini 的 display_errors = On。这个选项仅仅用于本地调试,千万不要在线上网站上打开。

php.ini 里面的 error_log = /your/log/path 选项可以控制错误日志输出到哪个文件,自己设置到一个方便查看的地方之后就可以不断去查看了。

一般调试错误就是用错误日志结合自己输出的 log,当然,如果在本地跑还可以用 Zend Studio IDE 的各种调试功能。

<code>if (!ini_get('display_errors')) {
    ini_set('display_errors', true);
}
</code>
声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn