博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
雷林鹏分享:Yii(yiiframework)框架(四):入口文件index.php
阅读量:6136 次
发布时间:2019-06-21

本文共 2113 字,大约阅读时间需要 7 分钟。

  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框架的工作流程:

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

转载于:https://www.cnblogs.com/linpeng1/p/10894661.html

你可能感兴趣的文章
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
Wait Functions
查看>>
代码描述10313 - Pay the Price
查看>>
jQuery最佳实践
查看>>
centos64i386下apache 403没有权限访问。
查看>>
vb sendmessage 详解1
查看>>
jquery用法大全
查看>>
PC-BSD 9.2 发布,基于 FreeBSD 9.2
查看>>
网卡驱动程序之框架(一)
查看>>
css斜线
查看>>
Windows phone 8 学习笔记(3) 通信
查看>>
重新想象 Windows 8 Store Apps (18) - 绘图: Shape, Path, Stroke, Brush
查看>>
Revit API找到风管穿过的墙(当前文档和链接文档)
查看>>
Scroll Depth – 衡量页面滚动的 Google 分析插件
查看>>
Windows 8.1 应用再出发 - 视图状态的更新
查看>>
自己制作交叉编译工具链
查看>>
Qt Style Sheet实践(四):行文本编辑框QLineEdit及自动补全
查看>>
[物理学与PDEs]第3章习题1 只有一个非零分量的磁场
查看>>
深入浅出NodeJS——数据通信,NET模块运行机制
查看>>
onInterceptTouchEvent和onTouchEvent调用时序
查看>>