Phalcon入坑必须知道的功能《Phalcon入坑指南系列 二》

本系列目录

一、Phalcon在Windows上安装 《Phalcon入坑指南系列 一》
二、Phalcon入坑必须知道的功能《Phalcon入坑指南系列 二》

前言

上一期文章是给大家介绍了Phalcon的安装,并且使用Phalcon开发工具进行创建了项目、控制器、模型。也就做了几个简单的操作。

本期给大家继续聊聊Phalcon的实战使用。

一、项目架构

项目目录结构

从上图可以看出这个目录结构跟TP框架极其相似,对应的目录就不一一解释了,这其中的migrations这个目录跟大家说一下。

这个目录就跟laravel中的数据库迁移一样,具体怎么使用就不细讲了哈!

框架结构也不是固定的,跟ThinkPHP也一样可以注册命名空间来修改目录结构。

在Phalcon框架中,咔咔最近负责的项目也是使用的多模块进行开发的。但是目录结构也跟使用Phalcon开发工具生成的目录是不一样的。

万变不离其宗,都是一个模样。

二、入口文件

每个框架必不可少的文件,index.php这个貌似是所有开发者默认的。

入口文件

那么在Phalcon这个框架中也是必不可少的了。

关于这里边加载的是什么就不去细细的剖析源码了,没那个必要,想看源码解析的可以去搜索ThinkPHP框架源码解析。

大体执行就是先进行依赖注入,使用/config/services.php引入一些文件其中你要着重知道的是在这里进行了数据库的连接。

这个文件/config/router.php看名字就知道是什么,路由呗!怎么设置路由,后边再说。

在就通过第一步依赖注入后获取配置信息。

最后一行代码就是include APP_PATH . '/config/loader.php';注册从配置信息中获取的目录。

三、配置Nginx

在第一期文章中没有对项目进行配置,接下来进行简单的配置一下。

Phalcon提供了三种方式的配置,咱们就先用最简单的第一种即可。

server {
        listen        80;
        server_name  www.kakaweb.com;
        root   "D:/phpstudy_pro/WWW/phalcon/public";
        index index.php index.html error/index.html;
	    location / {
	        try_files $uri $uri/ /index.php?_url=$uri&$args;
	    }

        
        location ~ \.php(.*)$ {
            fastcgi_pass   127.0.0.1:9002;
            fastcgi_index  index.php;
            fastcgi_split_path_info  ^((?U).+\.php)(/?.+)$;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_param  PATH_INFO  $fastcgi_path_info;
            fastcgi_param  PATH_TRANSLATED  $document_root$fastcgi_path_info;
            include        fastcgi_params;
        }
	
	    location ~ /\.ht {
	        deny all;
	    }
}

以上是咔咔的配置,如果你也使用的是PhpStudy,那么就可以直接复制过去使用。

四、控制器跳转

在第一期文章中,使用phalcon开发工具创建了控制器、模型,如果你还没有创建出来项目就需要去看第一期文章哈!

先看一下访问如何。

访问结果

代码实现

代码实现

可以看到在index控制器中,还建立了另一个方法kaka。

主流的框架都配置的是index控制器为默认访问路径,这个kaka怎么访问跟其它框架也是一样的。

访问链接就是http://www.kakaweb.com/index/kaka即可。

也就是域名+控制器+方法名,这里的方法名需要注意的是不需要带着Action。

访问kaka控制器

演练一下官方给的案例。

案例

可以看到输出结果就是一个a链接

响应结果

这个链接会直接跳转到Signup控制器,接下来使用开发者工具来生成一下这个控制器。

生成文件

接着点击刚刚那个按钮,就会跳转到Signup控制器了。

响应结果

关于控制器就先说到这里。

五、数据库之增、删、改、查

可以看到在模型文件中提前定义好了俩个方法,不管是啥,先来试试看。

数据库的方法

在控制器直接写上如下代码

控制器

查询结果

查看结果

由此可见

  • find方法是获取全部数据
  • findFirst只拿第一条数据
  • find(15)查询id为15的数据
  • find(“type = ‘mechanical’”); 条件搜索

插入数据

实现代码

    public function holdAction ()
    {
        $user = new User();

        $phql = "INSERT INTO User (name, age, sex) VALUES (:name:, :age:, :sex:)";

        $status = $user->modelsManager->executeQuery($phql, array(
            'name' => "咔咔1",
            'age' => 24,
            'sex' => 1
        ));

    }

实现结果

这里需要注意一下这个SQL语句$phql = "INSERT INTO User (name, age, sex) VALUES (:name:, :age:, :sex:)";

在这里User指的是模型,并不是数据库表名。

修改数据

实现代码

    public function modifyAction ()
    {
        $user = new User();

        $phql = "UPDATE User SET name = :name:, age = :age:, sex = :sex: WHERE id = :id:";

        $status = $user->modelsManager->executeQuery($phql, array(
            'id' => 20,
            'name' => "咔咔2",
            'age' => 25,
            'sex' => 2
        ));
    }

实现结果

删除数据

    public function deleteAction ()
    {
        $user = new User();

        $phql = "DELETE FROM User WHERE id = :id:";

        $status = $user->modelsManager->executeQuery($phql, array(
            'id' => 20
        ));

    }

可以看到已经没有结果了

删除数据

这时你会发现,在检索数据的时候用的框架自带的方法,到增、删、改使用的类似于原生了。

对于这个问题,如果你是新手建议会那种方式就用那种方式,因为工期可不等你。

使用框架修改的方式,咔咔也会给大家聊到,这个不用担心,下期文章哈!

六、代码优化

在第五节中,你们有没有发现到这个问题。

发现委问题

在所有的方法中,都进行了实例化User这个模型,这样做是可以。

但是你想想如果在项目初期就对满项目的使用这种方式,到中期发现需要改个名字,这时你怎么办?

全局搜索User关键字,改为修改的名字?

说实话这种方式没有几个程序员敢做这样的操作,因为你不知道哪里就会出现问题。

所以咔咔就给你们说一个统一管理这些模型的方法。

实现方案

可以将模型按照你自己的方式进行声明。

接着在控制器中进行初始化,在这里进行实例化模型。

此时你在想想如果改了表名,我们是不是只需要修改初始化方法里边的名字即可。

总结

本期文章给大家介绍了在使用一个框架时的必备功能。

虽然在增、删、改、查的过程中使用的是类似于原生的方式、这种方式在任何框架中都用的比较少。

但是不管是那种方式,都是代码对吧!不要对其嗤之以鼻,框架功能可以随意变化,但是这些SQL语句是终不会变化的。

坚持学习、坚持写作、坚持分享是咔咔从业以来一直所秉持的信念。希望在偌大互联网中咔咔的文章能带给你一丝丝帮助。我是咔咔,下期见。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Phalcon 中文文档 一般都是直接看英文资料,大都能看得懂。但看到Phalcon框架如此优秀,在学习后就想和大家分享,但发现国内的人几乎没有使用的,故想翻译一下,一旦翻译才发现读懂和译出一篇好文章真的不太一样。 故前一期翻译的部分章节有点生硬,等有空的时候再回头重译吧,后面的一部分也是以英文文档为基础,但并不再是逐句翻译了。 09年左右,大量的框架出现,我看过的框架不下20种,最先看到的可能就是php.MVC了,这是一个按照struts 1x编写的,只不过同时加载的类库太多了,效率不高而且不太完善。 后来稍有名的包括 cakephp, Symfony, Akelos, Prado, Kohana等,最近几年流行的就是 zf, yii, ci等,当然还有国内几个比较有名的框架,如fleaphp, thinkphp等。 在上面的一些框架中,我比较感冒的还是ci,yii,thinkphp等。ci,thinkphp够简单,速度也不错。yii是生活在国外的华人开发,功能够全而强大,速度也不错,国内的应用也不少。 一直不太喜欢zf,记得几年前就和同行朋友聊天的时候说,像ZEND公司完全可以用C语言开发出一个扩展来,这样效率会高得多,为毛非得用PHP开发呢,事实被我验证了,但开发扩展的不是ZEND公司,而是国内一个PHP大鸟,人称鸟哥。这个框架就是非常出名的YAF,因此YAF扩展是我必装的扩展之一。同时这也是我发现的第一个C语言写的扩展框架。 但YAF的缺点是,功能非常不完善,在我看来只是简单实现了MVC结构及路由,分发等功能,像一些ORM之类的功能完全没有开发,作者好像也没有开发的意思:) 后来就发现了Phalcon,一看文档就爱上了她,功能,速度等都是我想要的,我花了一周时间看文档学习她,并在一个下午的过程中,发现了文档中的三个错误并提交了这些错误:),我决定为完善它也贡献一点自己的力量。 本文档的中文地址存放在 http://phalcon.5iunix.net Github上的地址为: https://github.com/netstu/phalcondocs ,您如果发现有些地方译的有些操蛋,烦请你fork它,并完善她。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

咔咔-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值