function myErrorHandler($errno, $errstr, $errfile, $errline){
if(!(error_reporting() &$errno)){return;}
switch ($errno){
case E_USER_ERROR:
echo "<b>My ERROR</b> [$errno] $errstr<br/>";
echo "错误行:$errline 在文件:$errfile之中<br/>";
echo " PHP版本: " .PHP_VERSION ." (" .PHP_OS .")<br/>";
break;
case E_USER_WARNING:
echo "<b>My WARNING</b> [$errno] $errstr<br/>";
break;
case E_USER_NOTICE:
echo "<b>My NOTICE</b> [$errno] $errstr<br />";
break;
default:
echo "Unknown error type: [$errno] $errstr<br />";
break;
}
return true;
}
function trigger_test($age){//抛出错误的测试函数
if($age <= 0 || $age > 999) trigger_error("年龄不合法:$age岁", E_USER_ERROR);
if($age < 18) trigger_error("未成年:$age岁", E_USER_WARNING);
if($age > 40 && $age < 100) trigger_error("年龄稍大:$age岁", E_USER_NOTICE);
}
//如果只是简单统一地处理错误:
$errorHandler = set_error_handler("myErrorHandler");
trigger_test(1000);//会抛出一个error级的错误
function myError($errno, $errstr, $errfile, $errline){
print_r(func_get_args());
//具体处理方法
}
function myWarning($errno, $errstr, $errfile, $errline){
print_r(func_get_args());
//具体处理方法
}
function myNtice($errno, $errstr, $errfile, $errline){
print_r(func_get_args());
//具体处理方法
}
//如果要分别处理不同错误级别:
set_error_handler('myError',E_USER_ERROR);
set_exception_handler('myWarning',E_USER_WARNING);
set_exception_handler('myNtice',E_USER_NOTICE);
trigger_error('故意抛出个错误,还是很严重的哪一种!',E_USER_ERROR);
bool class_alias ( string $original , string $alias [, bool $autoload = TRUE ] ) — 为一个类创建别名
bool class_exists ( string $class_name [, bool $autoload ] )— 检查类是否已定义
string get_called_class ( void ) —获取静态方法调用的类名
class foo {
static public function test(){
var_dump(get_called_class());
}
}
class bar extends foo {}
foo::test();
bar::test();
array get_class_methods ( mixed $class_name )— 返回由类的方法名组成的数组
array get_class_vars ( string $class_name )— 返回由类的默认属性组成的数组
string get_class ([ object $obj ] )— 返回对象的类名
array get_declared_classes ( void )— 返回当前脚本中已定义类的名字组成的数组
array get_declared_interfaces ( void )— 返回当前脚本中所有已声明的接口的名字数组
array get_object_vars ( object $obj )— 返回由对象属性组成的关联数组
string get_parent_class ([ mixed $obj ] )— 返回对象或类的父类名
bool interface_exists ( string $interface_name [, bool $autoload ] )— 检查接口是否已被定义
bool is_a ( object $object , string $class_name )— 如果对象属于该类或该类是此对象的父类则返回 TRUE
bool is_subclass_of ( object $object , string $class_name )— 检测对象是该类的子类实例化得到的
bool method_exists ( object $object , string $method_name )— 检查类的方法是否存在
bool property_exists ( mixed $class , string $property ) — 检查对象或类是否具有该属性
flush():刷新输出程序缓存
for($i = 0; $i < 5; $i++){
echo str_repeat("\n", 5000);
echo $i;
sleep(1);
flush();
}
ob_start(回调函数,限定长度,随时输出缓存='true'):开启,前提:output_buffer = on
ob_clear():刷新
ob_end_clear():关闭,并刷新
ob_flush():输出
ob_end_flush():关闭,并输出
ob_get_contents:返回缓存
ob_get_clean():返回缓存,并刷新
ob_get_flush():返回缓存,并关闭
ob_get_length():返回缓存内容长度
ob_get_level():返回缓存嵌套级别
ob_get_status(返回所有的=false):返回缓存区状态
ob_gzhandler():压缩输出缓存,用作回调函数:ob_start('ob_gzhandler')
ob_implicit_flush(输出刷新=true):参数为true时,每次缓存输出都会自动刷新缓存
ob_list_handlers():列出所有正在使用缓存的函数。
output_add_rewrite_var(变量,值):添加URL重写器的值此函数给URL重写机制添加名/值对。 这种名值对将被添加到URL(以GET参数的形式)和表单(以input隐藏域的形式),当透明URL
重写用 session.use_trans_sid开启时同样可以添加到session ID。绝对URL(http://example.com/)不被重写,函数行为由url_rewriter.tags php.ini参数控制
output_add_rewrite_var('var', 'value');
echo '<a href="/blog_article/file.html">可以重写</a>'; //重写后:<a href="/blog_article/file/var/value.html">link</a>
echo '<a href="http://example.com">link2</a>';//绝对地址不被重写
echo '<form action="/blog_article/script.html" method="post"></form>'; //重写后:<form action="/blog_article/script.html" method="post"><input type="hidden" name="var" value="value" /></form>
output_reset_rewrite_vars():重置URL重写器的值,成功返回true
output_add_rewrite_var('var', 'value');
echo '<a href="/blog_article/file.html">不被重写</a>';
output_reset_rewrite_vars();//重置
echo '<a href="/blog_article/file.html">不被重写</a>';//重置了,地址不被重写