博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
phalcon-进阶篇2(拦截器)
阅读量:6583 次
发布时间:2019-06-24

本文共 2349 字,大约阅读时间需要 7 分钟。

phalcon-进阶篇2(拦截器)

本教程基于phalcon2.0.9版本

前言

先在这里感谢各位phalcon技术爱好者,我们提供这样一个优秀的交流平台

哈喽大家好啊!今天我们继续来说拦截器,拦截器在phalcon的文档里面称之为验证,但是我更喜欢叫做拦截器,拦截起主要是起到对于参数做验证的功能,如果你没有按照约定的规则来请求就报错,可以见得拦截器在请求中担当一个比较重要的地位,phalcon的拦截器能给我们带来什么新的惊喜呢?让我们来一探究竟把

注:笔者水平有限,说的不正确的地方希望大家多多指正,一同交流技术

附上:

喵了个咪的博客:

教程代码库:

phalcon官网地址:

phalcon中文社区:

1. 拦截器对比

买个关子,为什么一开始来不直接说是怎么实现呢?我们先来看看另外两个框架的拦截器分别是api开发框架phalapi和go框架beego

phalapi

'login' => array(   'username' => array('name' => 'username', 'require' => true),   'password' => array('name' => 'password', 'require' => true, 'min' => 6),),

beego

u := User{
"man", 40} valid := validation.Validation{} valid.Required(u.Name, "name") valid.MaxSize(u.Name, 15, "nameMax") valid.Range(u.Age, 0, 18, "age") if valid.HasErrors() { for _, err := range valid.Errors { log.Println(err.Key, err.Message) } }

phalcon

$validation = new Validation();$validation->add('name',new PresenceOf(array('message' => 'The name is required')));$validation->add('email',new PresenceOf(array('message' => 'The e-mail is required')));$validation->add('email',new Email(array('message' => 'The e-mail is not valid')));$messages = $validation->validate($_POST);if (count($messages)) {    foreach ($messages as $message) {        echo $message, '
'; }}

大家对比一下这三个框架的验证机制可以看出些什么,phalapi是一体式框架把后面的参数验证封装了,看看beego和phalcon是不是很像他们都是组件式框架,如果大家喜欢也可以自己封装成phalapi一样简单

2. phalcon拦截器

回到今天正题我们来讲讲phalcon的拦截器的使用,这里我建立了一个ValidationController代码如下:

use Phalcon\Validation;use Phalcon\Validation\Validator\Email;use Phalcon\Validation\Validator\PresenceOf;//初始化拦截器    $validation = new Validation();//定制你的拦截器规则,你需要验证的参数名比如:name,如果验证失败返回的message$validation->add(    'name', new PresenceOf(array(    'message' => 'The name is required')))->add(    'email', new PresenceOf(array(    'message' => 'The e-mail is required')))->add(    'email', new Email(array(    'message' => 'The e-mail is not valid')));//可以先过滤和清理请求参数$validation->setFilters('name', 'trim');$validation->setFilters('email', 'trim');//注入参数可以放get可以放post可以限制数据源$messages = $validation->validate($_REQUEST);//判断有没有验证通过if (count($messages)) {    //如果通过打印报错信息    foreach ($messages as $message) {       echo $message, '
'; } //结束执行后面的内容不再执行 return;}

我们试着访问一下应为我们什么都没有会得到如下返回:

如果我们带上请求参数这个时候请求是成功的

3. 小结

今天的内容就到这里了,大家有没有学到phalcon的拦截器呢,phalcon的拦截器还可以自己继承重写封装等等功能具体可以参考文档,这里只是简单说明一下,代码都会上传喜欢的话可以关注我的博客哦!

转载地址:http://gnsno.baihongyu.com/

你可能感兴趣的文章
Spring 下默认事务机制中@Transactional 无效的原因
查看>>
《转载》Spring MVC之@RequestBody, @ResponseBody 详解
查看>>
Spring IOC源代码具体解释之容器依赖注入
查看>>
【设置】Nginx配置文件具体配置解释
查看>>
LeetCode: Min Stack 解题报告
查看>>
LeetCode: Palindrome Partitioning II 解题报告
查看>>
iOS UI调试神器,插件injection for Xcode使用方法
查看>>
配置错误定义了重复的“system.web.extensions/scripting/scriptResourceHandler” 解决办法...
查看>>
.net平台下开源(免费)三维 GIS (地形,游戏)平台资料
查看>>
大公司 or 小公司
查看>>
.h和.cpp文件的区别(zt)
查看>>
SQLSERVER中的锁资源类型RID KEY PAG EXT TAB DB FIL
查看>>
将Datagridview中的数据导出至Excel中
查看>>
c++下面的一个单例
查看>>
git常用命令收藏【转】
查看>>
对象池
查看>>
Android开发环境搭建
查看>>
一个Jquery特效(转)
查看>>
使用log4j的时候如何输出printStackTrace()的堆栈信息
查看>>
微信中关闭网页输入内容时的安全提示 [干掉 “防盗号或诈骗,请不要输入QQ密码”]...
查看>>