我是用的是phpstudy2014的套件
但是我在部分地方做了修改使其能够同时兼容php5.3和5.2.7版本
修改地方为 vhosts.conf
loadfile d:/phpstudy/php52/php5ts.dllloadmodule php5_module d:/phpstudy/php52/php5apache2_4.dllphpinidir d:/phpstudy/php52/loadfile d:/phpstudy/php52/libmysql.dllloadfile 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.dllloadmodule php5_module d:/phpstudy/php52/php5apache2_4.dllphpinidir d:/phpstudy/php52/loadfile d:/phpstudy/php52/libmysql.dllloadfile 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);}