应用

    应用由 入口脚本 创建为一个单例对象。这个应用单例对象可以在任何地方通过 访问。

    默认情况下,应用是一个 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 事件。