开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1460|回复: 0
打印 上一主题 下一主题
收起左侧

[其它数据库例题] ZenTaoPHP框架中的数据验证机制

[复制链接]
跳转到指定楼层
楼主
发表于 2012-12-20 09:13:22 | 只看该作者 回帖奖励 |正序浏览 |阅读模式   山东省青岛市
本帖最后由 炒蚕豆吃蹦豆 于 2012-12-20 09:15 编辑

数据验证在web应用中尤其显得重要。下面来给大家介绍下禅道框架的数据验证机制。

一、首先来确定一个问题,即验证的规则放在什么地方?

mvc程序中,每一层都可以放验证规则。比如很多的表单验证,会自动根据用户的输入进行验证,然后给予提示。那么数据验证放在哪一层呢?这个问题网络上大家有很多的争议。有的人主要放在view这一层,有的则主张放在control层。禅道框架选择了model层。

为什么这样做呢?因为model层是最低的一层,所有的数据操作,都要经过model来进行处理。那么只要在这一关把数据验证做好,就可以保证数据的准确和安全。当然,框架的用户,可以同时在前端加上js的验证,和model层的验证不会冲突的。下面来看下如何使用禅道的数据过滤机制。

禅道的数据过滤分为两个部分,一个是数据修正,一个是数据验证。这个是受php的filter扩展启发,它里面就是分为了这两个部分。先来看数据修正的例子:

二、数据修正:

$bug = fixer::input('post')

->add('openedBy', $this->app->user->account)

->add('openedDate', $now)

->setDefault('project,story,task', 0)

->setDefault('openedBuild', '')

->setIF($this->post->assignedTo != '', 'assignedDate', $now)

->setIF($this->post->story != false, 'storyVersion', $this->loadModel('story')->getVersion($this->post->story))

->specialChars('title,steps,keyword')

->cleanInt('product, module, severity')

->join('openedBuild', ',')

->remove('files, labels')

->get();

首先,是调用fixer这个类的input方法,它的参数post表示是从$_POST这个变量中获取数据。

紧接着的两行add(),是向数据中增加两个变量。然后后面的两行setDefault则是表示,当这个变量没有传值的时候,设成默认的值。

接下来是两行setIF。setIF共有三个参数,第一个是判断条件,后面两个分别是key和value。也就是当条件为true的时候,设置$key = $value。

下面的spechialchars则表示对这三个字段进行htmlspecialchars处理;cleanInt则将变量处理成int类型,join,则将openedBuild使用,连接起来。

最后,还需要把两个不需要的变量去掉,使用remove。

通过get方法就可以得到一个已经经过修改的完整的数据集合。这个集合已经可以准备入库了。让我们来看下数据是如何验证的。

三、数据检查

$this->dao->insert(TABLE_BUG)->data($bug)->autoCheck()->batchCheck($this->config->bug->create->requiredFields, 'notempty')->exec();

这句sql插入语句通过data方法,将修正过的数据传递给dao对象,然后通过autoCheck()对其进行自动检查。autoCheck会根据数据库里面字段的类型,长度进行判断。如果类型不对,或者长度不对,会自动记录错误。然后后面调用了batchCheck()方法,对一批字段进行非空的验证。当然也可以通过check()方法对单个字段进行验证。验证的规则有很多,比如notempty, unique, email, account等等。

如果数据验证过程中没有错误,则执行了exec()方法,将数据插入数据库。如果有错呢?exec()方法则什么都只有执行。这个时候,就需要有control来进行判断了。

if(dao::isError()) die(js::error(dao::getError())); 对,就是这样一句话,如果dao::isError(),则执行getError()方法,然后将其合并成js的字符串,以警告框的形式弹出。执行了getError()之后,所有的错误被清空,这样不会影响下次的执行。

怎么样?朋友们,禅道框架的数据验证机制就是这样神奇的。赶快尝试下吧。
更多开源详情:http://www.zentao.net?u=lixiao&f=3600gz

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:[email protected]
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表