应用
应用由 入口脚本 创建为一个单例对象。这个应用单例对象可以在任何地方通过 访问。
默认情况下,应用是一个 CWebApplication 的实例。要自定义它,我们通常需要提供一个配置文件(或数组) 以创建应用实例时初始化其属性值。自定义应用的另一种方式是继承 。
配置是一个键值对数组。每个键代表应用实例中某属性的名字,每个值即相应属性的初始值。例如,如下的配置设定了应用的 name 和 属性。
我们通常在一个单独的PHP 脚本(e.g.protected/config/main.php
)中保存这些配置。在脚本中,我们通过以下方式返回此配置数组:
要应用此配置,我们将配置文件的名字作为参数传递给应用的构造器,或像下面这样传递到 Yii::createWebApplication()。这通常在 中完成:
应用基础目录指包含了所有安全敏感的PHP脚本和数据的根目录。默认状态下,它是一个位于含有入口脚本目录的名为protected
的子目录。它可以通过设置 application configuration中的 属性自定义。
在应用基础目录下的内容应该保护起来防止网站访客直接访问。对于 Apache HTTP服务器, 这可以通过在基础目录中放置一个 .htaccess
文件很简单的实现。 内容如下:
应用的功能可以通过其灵活的组件结构轻易地自定义或增强。应用管理了一系列应用组件,每个组件实现一特定功能。例如,应用通过 和 CHttpRequest 的帮助解析来自用户的请求。
通过配置应用的 属性,我们可以自定义应用中用到的任何组件类及其属性值。例如,我们可以配置应用的 CMemCache 组件,这样它就可以使用多个 memcache 服务器实现缓存:
如上所示,我们在 components
数组中添加了 cache
元素。cache
元素表明此组件的类是 CMemCache
,他的 属性应依此初始化。
要访问一个应用组件,使用 Yii::app()->ComponentID
,其中的 ComponentID
是指组件的ID(例如 Yii::app()->cache
)。
应用的组件可以通过在其配置中设置 enabled
为 false 禁用。当我们访问被禁用的组件时将返回 Null。
下面我们列出了由 预定义的核心组件。
assetManager: -管理私有资源文件的发布。
authManager: - 管理基于角色的访问控制 (RBAC).
cache: - 提供数据缓存功能。注意,你必须指定实际的类(例如CMemCache, )。否则,当你访问此组件时将返回 NULL。
clientScript: -管理客户端脚本 (javascripts 和 CSS).
coreMessages: -提供 Yii 框架用到的核心信息的翻译。
errorHandler: - 处理未捕获的 PHP 错误和异常。
format: - 格式化数值显示。此功能从版本 1.1.0 起开始提供。
messages: - 提供Yii应用中使用的信息翻译。
request: - 提供关于用户请求的信息。
securityManager: -提供安全相关的服务,例如散列,加密。
statePersister: - 提供全局状态持久方法。
urlManager: - 提供 URL 解析和创建相关功能
user: - 提供当前用户的识别信息。
themeManager: - 管理主题。
当处理用户请求时,应用将经历如下声明周期:
设置类的自动装载器和错误处理;
注册核心类组件;
加载应用配置;
通过 CApplication::init() 初始化应用:
- 注册应用行为;
- 载入静态应用组件;
触发 事件;
处理用户请求:
- 解析用户请求;
- 创建控制器;
- 触发 onEndRequest 事件。