phpcms v9 源码解析(3)pc_base::creat_app()



69     return self::load_sys_classs('application');
         在前面我们已经知道了,这个load_sys_classs 静态方法,它加载了PC_CMS/libs/classes/application.class.php
          默认的这个函数这个方法是实例化的,所以我们找到application.class.php,看看他的构造函数吧

构造函数就简单的几行代码,第15行,加载了param.class.php ,后面定义的常量都和param有关,让我们来看看这个类文件
  12          先声明一个私有变量  $route_config
                 下面的构造函数get_magin_quotes_gpc()是检测是否开启这个配置,new_addslashes()函数在global.func.php函数中定义了。

22            三元运算 ,我们打开route.php文件 ,返回了一个二维数组,
                其中下标为 'default'',我们就直接取出 default这个数组了,
               但是为什么phpcms要做这个判断呢,其中SITE_URL在base.php中定义了
               define('SITE_URL', (isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : ''));
               本地测试是 localhost ,是不是为了检测自己定义的路由规则呢?暂时不能知道了。
24-37    目前为止都是未执行的,因为 $this->route_config 其实是一个一维数组。
              你print_r($this->route_config)      Array( [m] => content [c] => index [a] => init)
              所以这个构造函数 ,只存在了个变量   $this->route_config



     这3个函数就比较简单 返回Array( [m] => content [c] => index [a] => init)里面的数据
  
OK,我们返回application.class.php
                         $this->init();
               
   26行,直接调用了load_controller ,我们直接看load_controller函数
第44行   load_controller($filename='',$m='') 上面的init并没有传参,
而且在构造函数中 我们已经取出了 ROUTR_C,ROUTE_M的值
那么 此时的$filename=index  $m=content
所以 47-63行的代码意思为
      判断 这个模块下的这个文件是否存在,存在就加载,同样判断了有没有以MY_开头的自己的扩展,有的话也加载,并实例化
      如果没有 就exit('Controller does not exist.');
 
回到init函数,此时已经加载了控制器,并实例化了index.php
init() 这个函数,主要注意的就是俩个函数 method_exists()和call_user_func()
不明白的同学,看手册吧,
这个call_user_func(array($controller,ROUTE_A))
直接就执行了 index.php里面的init方法
 
 好了,application.class.php函数就说到这吧,如果一篇写太多,朋友们看的时候会头大。
下一章,我们进去content模块下的index.php控制器的init方法
                                                                          
                                                    To Be Continued
原文地址:https://www.cnblogs.com/Hebe0115/p/3484976.html