转自:http://www.chrisyue.com/symfony-in-action-day-1.html







Symfony官方教程(推荐)
 http://www.symfony-project.org/doc/1_4/


 看源代码
 真的


 Symfony源代码中学习
 Symfony的插件库中学习更多





一些有用的工具和网址







 DoctrineExport
 http://code.google.com/p/mysql-workbench-doctrine-plugin/


 SymfonySnippets
 http://snippets.symfony-project.org/


 ORMDesigner
 http://www.orm-designer.com/symfony






===




大家点击源地址啊

Chrisyue's Blog

Open your API to change the internet, open your mind to change the world

跳至内容

Symfony 框架实战教程——第一天:创建项目

11条回复

Symfony 的官方教程其实已经非常的详尽,但却不太亲近新手。新手想要完全理解 Symfony 文档的内容,需要对互联网开发有一定工作经验才行,否则总是有一种看不太明白,看完了也不不知道从哪儿开始的感觉。如果你有这种感觉,希望这篇文章能让你快速上手,本篇的目的,就是为了让 Symfony 新手,甚至是 PHP 新手能快速开始一个具体的项目。

本篇系列重点是为了带领新手使用 Symfony 框架,如果您想了解的是 Symfony 组件,可阅读我翻译 Symfony 项目组老大的系列教程《使用 Symfony 组件创建自己的 PHP 框架》

本篇系列源代码位于 https://coding.net/u/chrisyue/p/symfony2-framework-tutorial/git,不过因为源代码已经包含各种添加修改重构之后的代码,看不到中间过程,建议在所有章节完成之后看,或者作为日后的参考。

2017-01-05 补充:目前 Symfony 已经发展到 3.2 版本。Symfony 严格遵循了标准的版本命名规则『API 如无法向下兼容时,大版本号 +1』,事实上 2 和 3 的区别不是很大,所以其实本教程应该也是适用于 Symfony3 的。如有不兼容处,请留言,我会更新相关的教程。

准备工作

下载并安装 PHP。Symfony 要求运行在 PHP 5.3 版本以上。不过随着 PHP 的版本提升,功能也越来越丰富,运行速度也有提升,所以我建议是最新的稳定版本。在 PHP 5.5 里自带了 web server,这意味着你甚至不需要 Nginx 或者 Apache 等服务就可以快速开始启动你的项目,所以没错,本教程就以 PHP 5.6(咦?难道不是 5.5 吗)为例子来讲解。

首先保证 PHP 在 PATH 目录里。

由于本篇主要阐述如何使用 Symfony 快速开发项目。所以不阐述 PHP 的安装相关知识,这些知识点在网上都很容易查询到。

初始化项目

本篇教程我尽量按照 Windows/*nix 都可以运行的方式来讲解。

得益于 Symfony installer,我们目前可以很方便的初始化一个 Symfony 项目。不过首先,你得有一个 Symfony installer。

随便创建一个目录:比如 www,然后在此目录下先安装 Symfony installer(注意 $ 为命令提示符,只是为了好看,实际操作的时候是不需要输入 $ 的,不再赘述):




1

$ php -r "readfile('http://symfony.com/installer');" > symfony.phar



然后运行以下命令确认文件可执行




1

$ php symfony.phar



如果文件无损坏,应该会显示 symfony installer 的版本号,以及如何使用 symfony installer 的简单介绍:




1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

Symfony Installer (0.5.0)

=========================

 

This is the official installer to start new projects based on the

Symfony full-stack framework.

 

To create a new project called blog in the current directory using

the latest stable version of Symfony, execute the following command:

 

  $ symfony.phar new blog

 

To base your project on a specific Symfony version, append the version

number at the end of the command:

 

  $ symfony.phar new blog 2.5.6

 

Updating the Symfony Installer

------------------------------

 

New versions of the Symfony Installer are released regularly. To update your

installer version, execute the following command:

 

  $ symfony.phar self-update



接下来,我们用 symfony.phar 来创建一个项目。这里我们打算做一个新闻聚合类网站,项目就叫 news 好了:




1

$ php symfony.phar new news



如果网络没有问题的话,应该会出现进度条(Windows 下可能没有……),此时 Symfony installer 在当前目录创建了 news 目录,并且初始化好 Symfony 框架的工作目录,以及下载所需要的第三方 PHP 库。




1

2

Downloading Symfony...

  85.81 KB/4.89 MB     1%



当下载完成后,进入 news 目录,我们可以看到 Symfony installer 为我们初始化的工作目录。这里我们可以把一些对开发来说没有必要的文件删除掉(UPGRADE-***,LICENSE,README.md)。

不出意外,我们便可以通过一下命令开启一个 Web server 监听在 localhost:8000 上(注:此命令只能运行在 PHP 5.5 版本之上,并且 Windows 可能只能运行 server:run,两者的区别你们自己试试就知道):




1

$ php app/console server:start localhost:8000



*** 注:在 3.0 以上的版本,console 已经位于 bin 目录下面,后面所有 php app/console xxx 命令,在新版本里都是 php bin/console xxx,以下不再赘述!

另外在 *nix 环境下,app/console 或者 bin/console 只要有可执行权限,都是可以不需要显式调用 php 而直接运行的:




1

$ app/console server:start



在浏览器里访问 http://localhost:8000,应该就可以看到 Symfony Framework 安装好之后的欢迎页面了

注意:如果访问不到首页,或者首页不是截图的样子,很有可能你安装的是 Symfony 2.7+ 版本,但并不影响后面的学习

至此,Symfony 项目初始化工作已经完成

我们可以使用 Symfony 框架自带的脚本工具,来确认当前的环境是否已经足够顺利运行 Symfony:




1

2

3

$ php app/check.php

# 在 Symfony 3.0+ 下

$ php bin/symfony_requirements



比如我这里显示的结果,命令运行结果推荐我安装 intl 扩展

另外我们也可以看到提示说因为命令行加载的 php.ini 可能和 web 服务器加载的不一样(常见的 php-fpm 一般都跟命令行下的 php 加载的不是同一个 php.ini 文件),建议在浏览器里查看 径 /config.php 复查一下。

==

附:我在安装时遇到的问题:


macdeMacBook-Pro:data mac$ php news/bin/symfony_requirements

Symfony Requirements Checker
~~~~~~~~~~~~~~~~~~~~~~~~~~~~

> PHP is using the following php.ini file:
  /usr/local/etc/php/5.6/php.ini


> Checking Symfony requirements:
  .....E......................WW......

                                                   
 [ERROR]                                           
 Your system is not ready to run Symfony2 projects
                                                   
Fix the following mandatory requirements
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

 * date.timezone setting must be set
   >Set the "date.timezone" setting in php.ini* (like Europe/Paris).
。。。

然后我自以为php.ini指的是,/private/etc/php.ini 修改了,重启了,还是报错。

就是没看清上面写着啊,
> PHP is using the following php.ini file:
  /usr/local/etc/php/5.6/php.ini