合规国际互联网加速 OSASE为企业客户提供高速稳定SD-WAN国际加速解决方案。 广告
# Phalcon 开发工具(Phalcon Developer Tools)[](# "永久链接至标题") Phalcon提供的这个开发工具主要是用来辅助开发,比如生成一些程序的基本框架,生成控制器模型等。使用这个工具我们只需要一个简单的命令即可生成应用的基本框架。 > **非常重要:** 要使用这个工具我们必须要安装Phalcon 0.5版本以上的扩展才行。这里我们推荐使用PHP5.3.6或更高版本的PHP. 如果你喜欢使用web版而非console版本的程序,那么在这里[blog post](http://blog.phalconphp.com/post/23251010409/dont-like-command-line-and-consoles-no-problem) 可以看到更多的内容。 ### 下载(Download)[](# "永久链接至标题") 我们可以从 [Github](https://github.com/phalcon/phalcon-devtools) 上下载或克隆下来这个跨平台的开发辅助工具。 ### 安装(Installation)[](# "永久链接至标题") 下面详尽的说明了如何在不同的操作系统平台上安装这个辅助开发工具: - [Windows 系统下使用 Phalcon 开发工具(Phalcon Developer Tools on Windows)](#) - [Mac OS X 系统下使用 Phalcon 开发工具(Phalcon Developer Tools on Mac OS X)](#) - [Linux 系统下使用 Phalcon 开发工具(Phalcon Developer Tools on Linux)](#) ### 获取可用的命令(Getting Available Commands)[](# "永久链接至标题") 我们可以在虚拟控制台上输入如下命令:phalcon commands ~~~ $ phalcon commands Phalcon DevTools (1.2.3) Available commands: commands (alias of: list, enumerate) controller (alias of: create-controller) model (alias of: create-model) all-models (alias of: create-all-models) project (alias of: create-project) scaffold migration webtools ~~~ ### 生成项目框架(Generating a Project Skeleton)[](# "永久链接至标题") 我们可以使用Phalcon开发辅助工具生成预先定义的项目架构。 默认情况下,phalcon开发辅助工具会使用apache的mod_rewrite来生成程序的骨架. 要创建项目我们只需要在我们的web服务器根目录下输入如下命令: ~~~ $ pwd /Applications/MAMP/htdocs $ phalcon create-project store ~~~ 执行命令后会生成如下的文档结构的项目: ![../_images/tools-2.png](https://box.kancloud.cn/2015-12-30_5683413c20b43.png) 我们可以在命令上加 *–help* 以显示帮助信息(下面的帮助中的中文是翻译时加上去的): ~~~ ~~~ Phalcon DevTools (1.2.3) Help:Creates a project 创建项目Usage:project [name] [type] [directory] [enable-webtools]Arguments: 参数help Shows this help text 显示此帮助信息Example 例子phalcon project store simpleOptions: 选项 <table class="first last docutils option-list" frame="void" rules="none"><col class="option"/><col class="description"/><tbody valign="top"><tr><td class="option-group"><kbd><span class="option">--name</span></kbd></td><td>Name of the new project 新项目的名字</td></tr><tr><td class="option-group" colspan="2"><kbd><span class="option">--enable-webtools</span></kbd></td></tr><tr><td> </td><td>Determines if webtools should be enabled [optional] 此选项决定了新的项目中是否使用webtools开发辅助组件</td></tr><tr><td class="option-group"><kbd><span class="option">--directory=<var>s</var></span></kbd></td><td>Base path on which project will be created [optional] 在何外创建项目</td></tr><tr><td class="option-group"><kbd><span class="option">--type=<var>s</var></span></kbd></td><td>Type of the application to be generated (micro, simple, modules, cli) 应用的种类(微型,简单,多模块,console等)</td></tr><tr><td class="option-group" colspan="2"><kbd><span class="option">--template-path</span></kbd></td></tr><tr><td> </td><td>Specify a template path [optional] 指定模板路径</td></tr><tr><td class="option-group" colspan="2"><kbd><span class="option">--use-config-ini</span></kbd></td></tr><tr><td> </td><td>Use a ini file as configuration file [optional] 使用ini文件作为配置保存文件</td></tr><tr><td class="option-group"><kbd><span class="option">--trace</span></kbd></td><td>Shows the trace of the framework in case of exception. [optional] 出错时是否显示框架的trace信息</td></tr><tr><td class="option-group"><kbd><span class="option">--help</span></kbd></td><td>Shows this help 显示帮助</td></tr></tbody></table> 我们访问新生成项目的地址显示如下: ![../_images/tools-6.png](https://box.kancloud.cn/2015-12-30_5683413c38cea.png) ### 生成控制器(Generating Controllers)[](# "永久链接至标题") 我们可以使用phalcon create-controller –name test或phalcon controller –name test来生成名为test的控制器. 当然要使用此命令当前的执行命令目录必须为已存在的phalcon项目内. ~~~ $ phalcon create-controller --name test ~~~ 上面的命令会生成如下代码: ~~~ <?php class TestController extends Phalcon\Mvc\Controller { public function indexAction() { } } ~~~ ### 数据库配置(Preparing Database Settings)[](# "永久链接至标题") 当我们使用phalcon的辅助开发工具生成项目时,则生成的配置信息会被放在 *app/config/config.ini* 文件内。 我们必须要正确的配置连接信息才可生成模型或基本的CRUD操作。可以在config.ini中进行修改配置信息: ~~~ [database] adapter = Mysql host = "127.0.0.1" username = "root" password = "secret" dbname = "store_db" [phalcon] controllersDir = "../app/controllers/" modelsDir = "../app/models/" viewsDir = "../app/views/" baseUri = "/store/" ~~~ ### 生成模型(Generating Models)[](# "永久链接至标题") 使用phalcon开发辅助工具我们可以有若干种方式来生成模型。 我人可以有选择的生成若干个模型或是全部生成。 亦可以指定生成公有属性或是生成setter和getter方法。 Options: | --name=s | Table name 表名 | |-----|-----| | --schema=s | Name of the schema. [optional] schema名 | | --namespace=s | Model's namespace [optional] 模型命名空间 | | --get-set | Attributes will be protected and have setters/getters. [optional] 设置字段访问属性为私有 并添加setters/getters方法 | | --extends=s | Model extends the class name supplied [optional] 指定扩展类名 | | --doc | Helps to improve code completion on IDEs [optional] 辅助IDE的自动完成功能 | | --directory=s | Base path on which project will be created [optional] 项目的根目录 | | --force | Rewrite the model. [optional] 重写模型 | | --trace | Shows the trace of the framework in case of exception. [optional] 出错时显示框架trace信息 | | --mapcolumn | Get some code for map columns. [optional] 生成字映射的代码 | 最简单的生成模型的方式: ~~~ $ phalcon model products ~~~ ~~~ $ phalcon model --name tablename ~~~ 所有的字段设置为公有: ~~~ <?php class Products extends \Phalcon\Mvc\Model { /** * @var integer */ public $id; /** * @var integer */ public $types_id; /** * @var string */ public $name; /** * @var string */ public $price; /** * @var integer */ public $quantity; /** * @var string */ public $status; } ~~~ 我们可以在生成模型时指定 *–get-set* 参数以实现对字面的保护, 这样我们可以在setter/getter方法里执行一些业务逻辑。 ~~~ <?php class Products extends \Phalcon\Mvc\Model { /** * @var integer */ protected $id; /** * @var integer */ protected $types_id; /** * @var string */ protected $name; /** * @var string */ protected $price; /** * @var integer */ protected $quantity; /** * @var string */ protected $status; /** * Method to set the value of field id * @param integer $id */ public function setId($id) { $this->id = $id; } /** * Method to set the value of field types_id * @param integer $types_id */ public function setTypesId($types_id) { $this->types_id = $types_id; } ... /** * Returns the value of field status * @return string */ public function getStatus() { return $this->status; } } ~~~ 另一个非常好的特性即是在我们多次生成模型时,原有的对模型的更改依然会存在。 这样我们就可以不用担心对模型的属性进行修会被后来再次执模型的生成命令所覆盖。下面的截图显示了这是如何工作的: ### 生成基本的 CRUD(Scaffold a CRUD)[](# "永久链接至标题") 使用phalcon开发辅助工具我们可以直接快速的生成一个模型的CRUD操作。 如果我们想快速的生成模型的CRUD操作只需要使用phalcon辅助开发工具的中scaffold命令即可。 代码生成后,你可以根据自己的需要修改生成的代码。很多开发者可能不会去使用这个功能,其实这东西有时不是太好用,很多时候开发者往往会手动的书写相关代码。使用scaffold产生的代码可以帮助我们理解框架是如何工作的当然也可以帮助我们制作出快速原型来。 下面的截图展示了基于products表的scaffold: ~~~ $ phalcon scaffold --table-name test ~~~ scaffold生成器会在相关的文件夹中生成若干个文档。 下面是所生成文件的概览: 在生成的Products控制器中,我们可以看到一个搜索表单和一个生成新product的链接: ![../_images/tools-10.png](https://box.kancloud.cn/2015-12-30_5683413c522d1.png) 在创建页面我们可以生成经过验证的Products记录。 Phalcon会自动的验证数据库中的非空字段。 ![../_images/tools-11.png](https://box.kancloud.cn/2015-12-30_5683413c6ed18.png) 执行搜索后,分页组件会显示颁后的结果。 我们在结果列表的前面放置Edit或Delete链接,以实现相应的操作。 ![../_images/tools-12.png](https://box.kancloud.cn/2015-12-30_5683413c90a3d.png) ### 工具的 Web 界面(Web Interface to Tools)[](# "永久链接至标题") 另外,如果你喜欢我们还可以在生成项目时通过添加参数以实现在项目中使用Phalcon开发工具的web接口。 下面的视频中展示了如何工作的: ### 集成工具到 PhpStorm(Integrating Tools with PhpStorm IDE)[](# "永久链接至标题") 下面的视频中展示了如何在 [PhpStorm IDE](http://www.jetbrains.com/phpstorm/) 中集成辅助开发工具。 这个配置步骤也适用于其它的PHP IDE. ### 结束语(Conclusion)[](# "永久链接至标题") Phalcon开发辅助工具为我们提供了一种简易的产生应用代码的方法, 这可以减少开发时间及潜在的错误。 | - [索引](# "总目录") - [下一页](# "Windows 系统下使用 Phalcon 开发工具(Phalcon Developer Tools on Windows)") | - [上一页](# "调试应用程序(Debugging Applications)") |