雷林鹏分享:Yii(yiiframework)框架(四):入口文件index.php

  Yii入口文件:

  // change the following paths if necessary

  $yii=dirname(__FILE__).'/../yii/framework/yii.php';

  $config=dirname(__FILE__).'/protected/config/main.php';

  // remove the following lines when in production mode

  defined('YII_DEBUG') or define('YII_DEBUG',true);

  // specify how many levels of call stack should be shown in each log message

  defined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3);

  require_once($yii);

  Yii::createWebApplication($config)->run();

  1、$yii=dirname(__FILE__).'/../yii/framework/yii.php'; 包含yii框架的引导文件yii.php,其实就是加载yii基础类YiiBase

  2、$config=dirname(__FILE__).'/protected/config/main.php'; 定义运用的配置文件

  3、defined('YII_DEBUG') or define('YII_DEBUG',true); 定义是否开启“调试模式”,默认为开启,建议在生产模式下关闭

  4、defined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3); 定义日志记录的级别。

  Yii 提供了一个灵活可扩展的日志功能。记录的日志可以通过日志级别和信息分类进行归类。通过使用级别和分类过滤器,所选的信息还可以进一步路由到不同的目的地,例如一个文件,Email,浏览器窗口等。

  在Yii 中有下列几种日志路由可用:

  CDbLogRoute: 将信息保存到数据库的表中。

  CEmailLogRoute: 发送信息到指定的 Email 地址。

  CFileLogRoute: 保存信息到应用程序 runtime 目录中的一个文件中。

  CWebLogRoute: 将 信息 显示在当前页面的底部。

  CProfileLogRoute: 在页面的底部显示概述(profiling)信息。

  同时我们也可以在应用的配置文件main.php中对日志记录功能进行设置:

  'log'=>array(

  'class'=>'CLogRouter',

  'routes'=>array(

  array(

  'class'=>'CFileLogRoute',

  'levels'=>'error, warning',

  ),

  // uncomment the following to show log messages on web pages

  /*

  array(

  'class'=>'CWebLogRoute',

  ),

  */

  ),

  ),

  5、Yii::createWebApplication($config)->run(); 创建CWebApplication类,CWebApplication是一个前端控制器,管理MVC中的控制器,提供核心组件。实例化是通过父类CApplication的构造函数进行路径别名映射,预初始化,初始化错误和异常handler,注册框架核心组件(CApplication中的coreMessages、db、message、errorHandler、securityManager、statePersister、urlManager、request、format和CWebApplication中的session、assetManager、user、themeManager、authManager、clientScript、widgetFactory),配置文件的配置数组,添加行为(attachBehaviors),初始化预加载的组件(配置文件中配置),最后执行init()预加载CHttpRequest对象。

  再回到index.php,执行前端控制器中的run()。首先执行onBeginReques事件如果有的话,接下来处理请求过程,和其他框架一样,获取路由然后分发路由,通过controller和action映射到指定的控制器文件。

  这里我们通过一张图来了解YII框架的工作流程:

yii框架工作流程

  文章转载自 [http://www.php230.com] (编辑:雷林鹏 来源:网络 侵删)

posted @ 2019-05-17 15:22  lei林鹏  阅读(177)  评论(0编辑  收藏  举报