欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

关于php报错的一个疑问

程序员文章站 2022-06-14 16:31:55
...
我是用的是phpstudy2014的套件
但是我在部分地方做了修改使其能够同时兼容php5.3和5.2.7版本
修改地方为 vhosts.conf

LoadFile "D:/phpStudy/php52/php5ts.dll"
LoadModule php5_module "D:/phpStudy/php52/php5apache2_4.dll"

PHPIniDir "D:/phpStudy/php52/"

LoadFile "D:/phpStudy/php52/libmysql.dll"
LoadFile "D:/phpStudy/php52/libmcrypt.dll"

    SetHandler application/x-httpd-php

    DocumentRoot "F:\github\xinyupingtai"
    ServerName d.hainuo.info
    ServerAlias hainuo.info

    Options FollowSymLinks ExecCGI
    AllowOverride All
    Order allow,deny
    Allow from all

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

error_reporting(0);

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

类的导入原理是

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;
}

我是用了一个方法是 $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:\*****\lib\dialog.php on line 1018

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

回复内容:

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


LoadFile "D:/phpStudy/php52/php5ts.dll"
LoadModule php5_module "D:/phpStudy/php52/php5apache2_4.dll"

PHPIniDir "D:/phpStudy/php52/"

LoadFile "D:/phpStudy/php52/libmysql.dll"
LoadFile "D:/phpStudy/php52/libmcrypt.dll"

    SetHandler application/x-httpd-php

    DocumentRoot "F:\github\xinyupingtai"
    ServerName d.hainuo.info
    ServerAlias hainuo.info

    Options FollowSymLinks ExecCGI
    AllowOverride All
    Order allow,deny
    Allow from all

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

error_reporting(0);

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

类的导入原理是

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;
}

我是用了一个方法是 $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:\*****\lib\dialog.php on line 1018

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

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

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

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

if (!ini_get('display_errors')) {
    ini_set('display_errors', true);
}
相关标签: php