# 安裝 Yii
你可以通過兩種方式安裝 Yii:使用?[Composer](https://getcomposer.org/)?或下載一個歸檔文件。推薦使用前者,這樣只需執行一條簡單的命令就可以安裝新的[擴展](http://www.yiichina.com/doc/guide/2.0/structure-extensions)或更新 Yii 了。
> 注意:和 Yii 1 不同,以標準方式安裝 Yii 2 時會同時下載并安裝框架本身和一個應用程序的基本骨架。
## 通過 Composer 安裝
如果還沒有安裝 Composer,你可以按?[getcomposer.org](https://getcomposer.org/download/)?中的方法安裝。在 Linux 和 Mac OS X 中可以運行如下命令:
~~~
curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
~~~
在 Windows 中,你需要下載并運行?[Composer-Setup.exe](https://getcomposer.org/Composer-Setup.exe)。
如果遇到任何問題或者想更深入地學習 Composer,請參考?[Composer 文檔(英文)](https://getcomposer.org/doc/),[Composer 中文](https://github.com/5-say/composer-doc-cn)。
如果你已經安裝有 Composer 請確保使用的是最新版本,你可以用?`composer self-update`?命令更新 Composer 為最新版本。
Composer 安裝后,切換到一個可通過 Web 訪問的目錄,執行如下命令即可安裝 Yii :
~~~
composer global require "fxp/composer-asset-plugin:~1.0.0"
composer create-project --prefer-dist yiisoft/yii2-app-basic basic
~~~
第一條命令安裝?[Composer asset plugin](https://github.com/francoispluchino/composer-asset-plugin/),它是通過 Composer 管理 bower 和 npm 包所必須的,此命令全局生效,一勞永逸。 第二條命令會將 Yii 安裝在名為?`basic`?的目錄中,你也可以隨便選擇其他名稱。
> 注意:在安裝過程中 Composer 可能會詢問你 GitHub 賬戶的登錄信息,因為可能在使用中超過了 GitHub API (對匿名用戶的)使用限制。因為 Composer 需要為所有擴展包從 GitHub 中獲取大量信息,所以超限非常正常。(譯注:也意味著作為程序猿沒有 GitHub 賬號,就真不能愉快地玩耍了)登陸 GitHub 之后可以得到更高的 API 限額,這樣 Composer 才能正常運行。更多細節請參考?[Composer 文檔](https://getcomposer.org/doc/articles/troubleshooting.md#api-rate-limit-and-oauth-tokens)(該段 Composer 中文文檔[期待您的參與](https://github.com/5-say/composer-doc-cn/blob/master/cn-introduction/articles/troubleshooting.md#api-rate-limit-and-oauth-tokens))。
> 技巧:如果你想安裝 Yii 的最新開發版本,可以使用以下命令代替,它添加了一個?[stability 選項](https://getcomposer.org/doc/04-schema.md#minimum-stability)([中文版](https://github.com/5-say/composer-doc-cn/blob/master/cn-introduction/04-schema.md#minimum-stability)):
>
> ~~~
> composer create-project --prefer-dist --stability=dev yiisoft/yii2-app-basic basic
> ~~~
>
> 注意,Yii 的開發版(dev 版)不應該用于生產環境中,它可能會破壞運行中的代碼。
## 通過歸檔文件安裝
通過歸檔文件安裝 Yii 包括三個步驟:
1. 從?[yiiframework.com](http://www.yiiframework.com/download/)?下載歸檔文件。
2. 將下載的文件解壓縮到 Web 目錄中。
3. 修改?`config/web.php`?文件,給?`cookieValidationKey`?配置項添加一個密鑰(若你通過 Composer 安裝,則此步驟會自動完成):
~~~
// !!! 在下面插入一段密鑰(若為空) - 以供 cookie validation 的需要
'cookieValidationKey' => '在此處輸入你的密鑰',
~~~
## 其他安裝方式
上文介紹了兩種安裝 Yii 的方法,安裝的同時也會創建一個立即可用的 Web 應用程序。對于小的項目或用于學習上手,這都是一個不錯的起點。
但是其他的安裝方式也存在:
* 如果你只想安裝核心框架,然后從零開始構建整個屬于你自己的應用程序模版,可以參考[從頭構建自定義模版](http://www.yiichina.com/doc/guide/2.0/tutorial-start-from-scratch)一節的介紹。
* 如果你要開發一個更復雜的應用,可以更好地適用于團隊開發環境的,可以考慮安裝[高級應用模版](http://www.yiichina.com/doc/guide/2.0/tutorial-advanced-app)。
## 驗證安裝的結果
安裝完成后,就可以使用瀏覽器通過如下 URL 訪問剛安裝完的 Yii 應用了:
~~~
http://localhost/basic/web/index.php
~~~
這個 URL 假設你將 Yii 安裝到了一個位于 Web 文檔根目錄下的?`basic`?目錄中,且該 Web 服務器正運行在你自己的電腦上(`localhost`)。你可能需要將其調整為適應自己的安裝環境。

你應該可以在瀏覽器中看到如上所示的 “Congratulations!” 頁面。如果沒有,請通過以下任意一種方式,檢查當前 PHP 環境是否滿足 Yii 最基本需求:
* 通過瀏覽器訪問 URL?`http://localhost/basic/requirements.php`
* 執行如下命令:
~~~
cd basic
php requirements.php
~~~
你需要配置好 PHP 安裝環境,使其符合 Yii 的最小需求。主要是需要 PHP 5.4 以上版本。如果應用需要用到數據庫,那還要安裝?[PDO PHP 擴展](http://www.php.net/manual/zh/pdo.installation.php)?和相應的數據庫驅動(例如訪問 MySQL 數據庫所需的?`pdo_mysql`)。
## 配置 Web 服務器
>補充:如果你現在只是要試用 Yii 而不是將其部署到生產環境中,本小節可以跳過。
通過上述方法安裝的應用程序在 Windows,Max OS X,Linux 中的?[Apache HTTP 服務器](http://httpd.apache.org/)或?[Nginx HTTP 服務器](http://nginx.org/)且PHP版本為5.4或更高都可以直接運行。Yii 2.0 也兼容 Facebook 公司的?[HHVM](http://hhvm.com/),由于 HHVM 和標準 PHP 在邊界案例上有些地方略有不同,在使用 HHVM 時需稍作處理。
在生產環境的服務器上,你可能會想配置服務器讓應用程序可以通過 URL?`http://www.example.com/index.php`?訪問而不是`http://www.example.com/basic/web/index.php`。這種配置需要將 Web 服務器的文檔根目錄指向?`basic/web`?目錄。可能你還會想隱藏掉 URL 中的?`index.php`,具體細節在?[URL 解析和生成](http://www.yiichina.com/doc/guide/2.0/runtime-url-handling)一章中有介紹,你將學到如何配置 Apache 或 Nginx 服務器實現這些目標。
>補充:將?`basic/web`?設置為文檔根目錄,可以防止終端用戶訪問?`basic/web`?相鄰目錄中的私有應用代碼和敏感數據文件。禁止對其他目錄的訪問是一個不錯的安全改進。
>補充:如果你的應用程序將來要運行在共享虛擬主機環境中,沒有修改其 Web 服務器配置的權限,你依然可以通過調整應用的結構來提升安全性。詳情請參考[共享主機環境](http://www.yiichina.com/doc/guide/2.0/tutorial-shared-hosting)?一章。
### 推薦使用的 Apache 配置
在 Apache 的?`httpd.conf`?文件或在一個虛擬主機配置文件中使用如下配置。注意,你應該將?`path/to/basic/web`?替換為實際的`basic/web`?目錄。
~~~
# 設置文檔根目錄為 “basic/web”
DocumentRoot "path/to/basic/web"
<Directory "path/to/basic/web">
# 開啟 mod_rewrite 用于美化 URL 功能的支持(譯注:對應 pretty URL 選項)
RewriteEngine on
# 如果請求的是真實存在的文件或目錄,直接訪問
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# 如果請求的不是真實文件或目錄,分發請求至 index.php
RewriteRule . index.php
# ...其它設置...
</Directory>
~~~
### 推薦使用的 Nginx 配置
為了使用?[Nginx](http://wiki.nginx.org/),你應該已經將 PHP 安裝為?[FPM SAPI](http://php.net/install.fpm)?了。使用如下 Nginx 配置,將?`path/to/basic/web`?替換為實際的`basic/web`?目錄,`mysite.local`?替換為實際的主機名以提供服務。
~~~
server {
charset utf-8;
client_max_body_size 128M;
listen 80; ## 監聽 ipv4 上的 80 端口
#listen [::]:80 default_server ipv6only=on; ## 監聽 ipv6 上的 80 端口
server_name mysite.local;
root /path/to/basic/web;
index index.php;
access_log /path/to/basic/log/access.log main;
error_log /path/to/basic/log/error.log;
location / {
# 如果找不到真實存在的文件,把請求分發至 index.php
try_files $uri $uri/ /index.php?$args;
}
# 若取消下面這段的注釋,可避免 Yii 接管不存在文件的處理過程(404)
#location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ {
# try_files $uri =404;
#}
#error_page 404 /404.html;
location ~ \.php$ {
include fastcgi.conf;
fastcgi_pass 127.0.0.1:9000;
#fastcgi_pass unix:/var/run/php5-fpm.sock;
try_files $uri =404;
}
location ~ /\.(ht|svn|git) {
deny all;
}
}
~~~
使用該配置時,你還應該在?`php.ini`?文件中設置?`cgi.fix_pathinfo=0`?,能避免掉很多不必要的?`stat()`?系統調用。
還要注意當運行一個 HTTPS 服務器時,需要添加?`fastcgi_param HTTPS on;`?一行,這樣 Yii 才能正確地判斷連接是否安全。
- 介紹(Introduction)
- 關于 Yii(About Yii)
- 從 Yii 1.1 升級(Upgrading from Version 1.1)
- 入門(Getting Started)
- 安裝 Yii(Installing Yii)
- 運行應用(Running Applications)
- 第一次問候(Saying Hello)
- 使用 Forms(Working with Forms)
- 玩轉 Databases(Working with Databases)
- 用 Gii 生成代碼(Generating Code with Gii)
- 更上一層樓(Looking Ahead)
- 應用結構(Application Structure)
- 結構概述(Overview)
- 入口腳本(Entry Scripts)
- 應用(Applications)
- 應用組件(Application Components)
- 控制器(Controllers)
- 模型(Models)
- 視圖(Views)
- 模塊(Modules)
- 過濾器(Filters)
- 小部件(Widgets)
- 前端資源(Assets)
- 擴展(Extensions)
- 請求處理(Handling Requests)
- 運行概述(Overview)
- 引導(Bootstrapping)
- 路由引導與創建 URL(Routing and URL Creation)
- 請求(Requests)
- 響應(Responses)
- Sessions and Cookies
- 錯誤處理(Handling Errors)
- 日志(Logging)
- 關鍵概念(Key Concepts)
- 組件(Components)
- 屬性(Properties)
- 事件(Events)
- 行為(Behaviors)
- 配置(Configurations)
- 別名(Aliases)
- 類自動加載(Class Autoloading)
- 服務定位器(Service Locator)
- 依賴注入容器(Dependency Injection Container)
- 配合數據庫工作(Working with Databases)
- 數據庫訪問(Data Access Objects): 數據庫連接、基本查詢、事務和模式操作
- 查詢生成器(Query Builder): 使用簡單抽象層查詢數據庫
- 活動記錄(Active Record): 活動記錄對象關系映射(ORM),檢索和操作記錄、定義關聯關系
- 數據庫遷移(Migrations): 在團體開發中對你的數據庫使用版本控制
- Sphinx
- Redis
- MongoDB
- ElasticSearch
- 接收用戶數據(Getting Data from Users)
- 創建表單(Creating Forms)
- 輸入驗證(Validating Input)
- 文件上傳(Uploading Files)
- 收集列表輸入(Collecting Tabular Input)
- 多模型同時輸入(Getting Data for Multiple Models)
- 顯示數據(Displaying Data)
- 格式化輸出數據(Data Formatting)
- 分頁(Pagination)
- 排序(Sorting)
- 數據提供器(Data Providers)
- 數據小部件(Data Widgets)
- 操作客戶端腳本(Working with Client Scripts)
- 主題(Theming)
- 安全(Security)
- 認證(Authentication)
- 授權(Authorization)
- 處理密碼(Working with Passwords)
- 客戶端認證(Auth Clients)
- 安全領域的最佳實踐(Best Practices)
- 緩存(Caching)
- 概述(Overview)
- 數據緩存(Data Caching)
- 片段緩存(Fragment Caching)
- 分頁緩存(Page Caching)
- HTTP 緩存(HTTP Caching)
- RESTful Web 服務
- 快速入門(Quick Start)
- 資源(Resources)
- 控制器(Controllers)
- 路由(Routing)
- 格式化響應(Response Formatting)
- 授權驗證(Authentication)
- 速率限制(Rate Limiting)
- 版本化(Versioning)
- 錯誤處理(Error Handling)
- 開發工具(Development Tools)
- 調試工具欄和調試器(Debug Toolbar and Debugger)
- 使用 Gii 生成代碼(Generating Code using Gii)
- TBD 生成 API 文檔(Generating API Documentation)
- 測試(Testing)
- 概述(Overview)
- 搭建測試環境(Testing environment setup)
- 單元測試(Unit Tests)
- 功能測試(Functional Tests)
- 驗收測試(Acceptance Tests)
- 測試夾具(Fixtures)
- 高級專題(Special Topics)
- 高級應用模版(Advanced Project Template)
- 從頭構建自定義模版(Building Application from Scratch)
- 控制臺命令(Console Commands)
- 核心驗證器(Core Validators)
- 國際化(Internationalization)
- 收發郵件(Mailing)
- 性能優化(Performance Tuning)
- 共享主機環境(Shared Hosting Environment)
- 模板引擎(Template Engines)
- 集成第三方代碼(Working with Third-Party Code)
- 小部件(Widgets)
- Bootstrap 小部件(Bootstrap Widgets)
- jQuery UI 小部件(jQuery UI Widgets)
- 助手類(Helpers)
- 助手一覽(Overview)
- Array 助手(ArrayHelper)
- Html 助手(Html)
- Url 助手(Url)