spl_autoload_register()和__autoload()

这也是OO设计的基本思想之一。在PHP5之前,如果需要使用一个类,只需要直接使用include/require将其包含进来即可。下面是一个实际的例子: 

 
 1 class ClassA{ 
 2     public function __construct(){ 
 3         echo “ClassA load success!”; 
 4     } 
 5 } 
 6 //定义一个类ClassA,文件名为ClassA.php 
 7 class ClassA{ 
 8     public function __construct(){ 
 9         echo “ClassA load success!”; 
10     } 
11 } 
12 class ClassB extends ClassA { 
13     public function __construct(){ 
14         //parent::__construct(); 
15         echo “ClassB load success!”; 
16     } 
17 } 
18 //定义一个类ClassB,文件名为ClassB.php,ClassB继承ClassA 
19 class ClassB extends ClassA { 
20     public function __construct(){ 
21         //parent::__construct(); 
22         echo “ClassB load success!”; 
23     } 
24 } 
25 //定义两个测试用的类之后,我们来编写一个含有__autoload()方法的PHP运行程序文件如下: 
26 function __autoload($classname){ 
27     $classpath=”./”.$classname.'.php'; 
28     if(file_exists($classpath)){ 
29         require_once($classpath); 
30     } else{ 
31         echoclass file'.$classpath.'not found!'; 
32     } 
33 } 
34 
35 $newobj = new ClassA(); 
36 $newobj = new ClassB(); 

 

这个文件的运行是一点问题都没有的.
但是不得不提醒你一下几个方面是必须要注意的。 


1、如果类存在继承关系(例如:ClassB extends ClassA),并且ClassA不在ClassB所在目录 
利用__autoload魔术函数实例化ClassB的时候就会受到一个致命错误: 
Fatal error: Class ‘Classd' not found in ……ClassB.php on line 2, 


解决方法:把所有存在extends关系的类放在同一个文件目录下,或者在实例化一个继承类的时候在文件中手工包含被继承的类; 


2、另外一个需要注意的是,类名和类的文件名必须一致,才能更方便的使用魔术函数__autoload; 


3、在CLI模式下运行PHP脚本的话这个方法无效; 


4、如果你的类名称和用户的输入有关——或者依赖于用户的输入,一定要注意检查输入的文件名,例如:.././这样的文件名是非常危险的。

 
posted @ 2017-10-20 21:40  苍山雪洱海月  阅读(156)  评论(0编辑  收藏  举报