Yii2 framework backup
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

236 lines
11 KiB

10 years ago
安装 Yii
==============
8 years ago
你可以通过两种方式安装 Yii:使用 [Composer](http://getcomposer.org/) 或下载一个归档文件。
推荐使用前者,这样只需执行一条简单的命令就可以安装新的[扩展](structure-extensions.md)或更新 Yii 了。
10 years ago
标准安装完Yii之后,框架和一个项目模板两者都下载并安装好了。
一个项目模板是实现了一些基本特性的一个 可行的Yii项目,比如登录,联系表单,等等。
它的代码是以推荐的方式组织的。因此,它能够适合作为你项目的一个好的起点。
8 years ago
在本章节和以后的章节,我们将会介绍如何去安装Yii和所谓的*基本的应用程序模板*和如何去实现这个模板上的新特性。Yii当然也提供了其它模板叫[高级的应用程序模板](https://github.com/yiisoft/yii2-app-advanced/blob/master/docs/guide/README.md),它是更好应用于在一个团队开发环境中去开发多层级的应用程序。
10 years ago
> 信息:这个基本的应用程序模板是适合于开发90%的Web应用程序。
它不同于高级的应用程序模板主要地在如何使它们的代码是有组织的。如果你是刚接触Yii,我们强烈建议你坚持使用简单并有足够的功能的基础的应用程序模板。
10 years ago
通过 Composer 安装 <span id="installing-via-composer"></span>
10 years ago
-----------------------
8 years ago
如果还没有安装 Composer,你可以按 [getcomposer.org](https://getcomposer.org/download/) 中的方法安装。
在 Linux 和 Mac OS X 中,你可以运行如下命令:
10 years ago
8 years ago
```bash
curl -sS https://getcomposer.org/installer | php
mv composer.phar /usr/local/bin/composer
```
10 years ago
在 Windows 中,你需要下载并运行 [Composer-Setup.exe](https://getcomposer.org/Composer-Setup.exe)。
8 years ago
如果遇到任何问题或者想更深入地学习 Composer,
请参考 [Composer 文档(英文)](https://getcomposer.org/doc/),[Composer 中文](https://github.com/5-say/composer-doc-cn)。
10 years ago
8 years ago
如果你已经安装有 Composer 请确保使用的是最新版本,
你可以用 `composer self-update` 命令更新 Composer 为最新版本。
10 years ago
Composer 安装后,切换到一个可通过 Web 访问的目录,执行如下命令即可安装 Yii :
8 years ago
```bash
composer global require "fxp/composer-asset-plugin:^1.2.0"
8 years ago
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
8 years ago
> 中获取大量信息,所以超限非常正常。(译注:也意味着作为程序猿没有 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))。
10 years ago
> 提示: 如果你想安装 Yii 的最新开发版本,可以使用以下命令代替,
8 years ago
> 它添加了一个 [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)):
10 years ago
>
8 years ago
> ```bash
> composer create-project --prefer-dist --stability=dev yiisoft/yii2-app-basic basic
> ```
10 years ago
>
> 注意,Yii 的开发版(dev 版)不应该用于生产环境中,它可能会破坏运行中的代码。
10 years ago
通过归档文件安装 <span id="installing-from-archive-file"></span>
10 years ago
-------------------------------
通过归档文件安装 Yii 包括三个步骤:
10 years ago
1. 从 [yiiframework.com](http://www.yiiframework.com/download/) 下载归档文件。
2. 将下载的文件解压缩到 Web 访问的文件夹中。
8 years ago
3. 修改 `config/web.php` 文件,给 `cookieValidationKey` 配置项
添加一个密钥(若你通过 Composer 安装,则此步骤会自动完成):
```php
// !!! 在下面插入一段密钥(若为空) - 以供 cookie validation 的需要
'cookieValidationKey' => '在此处输入你的密钥',
```
10 years ago
其他安装方式 <span id="other-installation-options"></span>
10 years ago
--------------------------
8 years ago
上文介绍了两种安装 Yii 的方法,
安装的同时也会创建一个立即可用的 Web 应用程序。
这个方法对大多数的大或者小的项目是一个不错的起点。如果你正好开始学习Yii,这是特别适合的。
10 years ago
但是其他的安装方式也存在:
10 years ago
8 years ago
* 如果你只想安装核心框架,然后从零开始构建整个属于你自己的应用程序模版,
可以参考[从头构建自定义模版](tutorial-start-from-scratch.md)一节的介绍。
* 如果你要开发一个更复杂的应用,可以更好地适用于团队开发环境的,
你可以考虑安装[高级应用模版](tutorial-advanced-app.md)。
10 years ago
验证安装的结果 <span id="verifying-installation"></span>
10 years ago
--------------------------
当安装完成之后,或配置你的Web服务器(看下面的文章)或使用[内置Web Server](https://secure.php.net/manual/en/features.commandline.webserver.php),当在项目 `web` 目录下可以通过下面的命令:
8 years ago
```bash
php yii serve
```
> 注意:默认情况下Https-server将监听8080。可是如果这个端口已经使用或者你想通过这个方式运行多个应用程序,你可以指定使用哪些端口。只加上 --port 参数:
8 years ago
```bash
php yii serve --port=8888
```
安装完成后,就可以使用浏览器通过如下 URL 访问刚安装完的 Yii 应用了:
10 years ago
```
8 years ago
http://localhost:8080/
10 years ago
```
10 years ago
![Yii 安装成功](images/start-app-installed.png)
10 years ago
8 years ago
你应该可以在浏览器中看到如上所示的 “Congratulations!” 页面。如果没有,
请通过以下任意一种方式,检查当前 PHP 环境是否满足 Yii 最基本需求:
10 years ago
* 复制 `/requirements.php``/web/requirements.php`,然后通过浏览器访问 URL `http://localhost/requirements.php`
10 years ago
* 执行如下命令:
10 years ago
```
cd basic
php requirements.php
```
你需要配置好 PHP 安装环境,使其符合 Yii 的最小需求。主要是需要 PHP 5.4 或 以上版本。
8 years ago
如果应用需要用到数据库,那还要安装 [PDO PHP 扩展](http://www.php.net/manual/zh/pdo.installation.php)
和相应的数据库驱动(例如访问 MySQL 数据库所需的 `pdo_mysql`)。
10 years ago
配置 Web 服务器 <span id="configuring-web-servers"></span>
10 years ago
-----------------------
> 提示: 如果你现在只是要试用 Yii 而不是将其部署到生产环境中,
8 years ago
本小节可以跳过。
10 years ago
8 years ago
通过上述方法安装的应用程序在 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 时需稍作处理。
10 years ago
8 years ago
在生产环境的服务器上,你可能会想配置服务器让应用程序可以通过
URL `http://www.example.com/index.php` 访问而不是 `http://www.example.com/basic/web/index.php`
这种配置需要将 Web 服务器的文档根目录(document root)指向 `basic/web` 目录。
8 years ago
可能你还会想隐藏掉 URL 中的 `index.php`,具体细节在 [URL 解析和生成](runtime-url-handling.md)一章中有介绍,
你将学到如何配置 Apache 或 Nginx 服务器实现这些目标。
10 years ago
> 信息: 将 `basic/web` 设置为文档根目录(document root),可以防止终端用户访问 `basic/web` 相邻目录中
8 years ago
的私有应用代码和敏感数据文件。
禁止对其他目录的访问是一个不错的安全改进。
10 years ago
> 信息: 如果你的应用程序将来要运行在共享虚拟主机环境中,
8 years ago
没有修改其 Web 服务器配置的权限,你依然可以通过调整应用的结构来提升安全性。
详情请参考[共享主机环境](tutorial-shared-hosting.md) 一章。
10 years ago
### 推荐使用的 Apache 配置 <span id="recommended-apache-configuration"></span>
10 years ago
8 years ago
在 Apache 的 `httpd.conf` 文件或在一个虚拟主机配置文件中使用如下配置。
注意,你应该将 `path/to/basic/web` 替换为实际的 `basic/web` 目录。
10 years ago
```
# 设置文档根目录为 "basic/web"
10 years ago
DocumentRoot "path/to/basic/web"
<Directory "path/to/basic/web">
10 years ago
# 开启 mod_rewrite 用于美化 URL 功能的支持(译注:对应 pretty URL 选项)
10 years ago
RewriteEngine on
# 如果请求的是真实存在的文件或目录,直接访问
10 years ago
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# 如果请求的不是真实文件或目录,分发请求至 index.php
10 years ago
RewriteRule . index.php
# ...其它设置...
10 years ago
</Directory>
```
### 推荐使用的 Nginx 配置 <span id="recommended-nginx-configuration"></span>
10 years ago
8 years ago
为了使用 [Nginx](http://wiki.nginx.org/),你应该已经将 PHP 安装为 [FPM SAPI](http://php.net/install.fpm) 了。
你可以使用如下 Nginx 配置,将 `path/to/basic/web` 替换为实际的 `basic/web` 目录,
8 years ago
`mysite.local` 替换为实际的主机名以提供服务。
10 years ago
8 years ago
```nginx
10 years ago
server {
charset utf-8;
client_max_body_size 128M;
8 years ago
listen 80; ## listen for ipv4
#listen [::]:80 default_server ipv6only=on; ## listen for ipv6
10 years ago
server_name mysite.local;
root /path/to/basic/web;
index index.php;
8 years ago
access_log /path/to/basic/log/access.log;
10 years ago
error_log /path/to/basic/log/error.log;
location / {
8 years ago
# Redirect everything that isn't a real file to index.php
try_files $uri $uri/ /index.php$is_args$args;
10 years ago
}
8 years ago
# uncomment to avoid processing of calls to non-existing static files by Yii
10 years ago
#location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ {
# try_files $uri =404;
#}
#error_page 404 /404.html;
# deny accessing php files for the /assets directory
location ~ ^/assets/.*\.php$ {
deny all;
}
10 years ago
location ~ \.php$ {
8 years ago
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_pass 127.0.0.1:9000;
10 years ago
#fastcgi_pass unix:/var/run/php5-fpm.sock;
try_files $uri =404;
10 years ago
}
location ~* /\. {
10 years ago
deny all;
}
}
```
8 years ago
使用该配置时,你还应该在 `php.ini` 文件中设置 `cgi.fix_pathinfo=0`
能避免掉很多不必要的 `stat()` 系统调用。
10 years ago
8 years ago
还要注意当运行一个 HTTPS 服务器时,需要添加 `fastcgi_param HTTPS on;` 一行,
这样 Yii 才能正确地判断连接是否安全。