加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 输入过滤器/验证码是否属于控制器或域模型?

发布时间:2020-12-13 17:20:47 所属栏目:PHP教程 来源:网络整理
导读:我一直在使用php一段时间,但我是OO php的新手.作为我自己的练习,我正在构建一个小型的MVC框架. 我意识到可能没有明确的答案,但我想知道:输入过滤器/验证码属于哪里? 它应该是控制器的一部分,在哪里解析请求? 或者在域模型中使用过滤器/验证代码更合适,以
我一直在使用php一段时间,但我是OO php的新手.作为我自己的练习,我正在构建一个小型的MVC框架.

我意识到可能没有明确的答案,但我想知道:输入过滤器/验证码属于哪里?

它应该是控制器的一部分,在哪里解析请求?

或者在域模型中使用过滤器/验证代码更合适,以便每个域对象负责验证自己的信息.

任何建议将不胜感激.

解决方法

控制器通常会处理请求数据(GET / POST)并检测模型不应该关注的无效表单提交,CSRF,缺失字段等.这是您编写大部分过滤代码的最可能的地方;验证应该只进行早期失败的完整性检查(例如,如果它不是有效的电子邮件地址,请不要费心向模型发送电子邮件地址).

您的域对象也可能提供验证挂钩(甚至过滤),这会降低控制器的责任,但在大多数情况下,我个人觉得使用基于合同的模型更容易(模型假设您传递合法值),因为它更容易直接将验证问题转换为特定表单字段.

模型本身也可以进行验证,尽管与上述输入过滤(和内容类型验证)不同;例如,它可能会检查数据库中是否存在电子邮件,而不是确保它是有效的电子邮件地址.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读