Validation 问题域

Validation 问题域 - 切尔斯基 - 博客频道 - CSDN.NET http://blog.csdn.net/chelsea/article/details/5700353?locationNum=5

谁来做Validation
何时做Validation
如何表达错误
如何传递错误
如何关联错误到发生错误的对象, 尤其是对象图中非Root对象

这里的Validation指的是对进入到系统中的业务数据的校验(不包括Web应用中页面数据在浏览器端的验证)
谁来做Validation
数据的有效性不是自身所能决定的, 而是使用它的场景(Context)决定的, 因此, 每个Context应该有自己的Validation逻辑.一个例子, 个人信息残缺, 比如婚姻状况没填, 但联系地址电子邮件等信息完备, 那么这个个人信息到底是合法还是非法? 如果你的应用是个税务相关的应用必须知道婚姻状况则数据是非法的, 如果你的应用是CRM系统有客户的联系方式即可而婚姻状况是可选的则数据就是合法的. 问题是你的应用是税务应用但同时支持客户关系管理, 那这段数据到底合法非法? 税务应用只是年底的时候才有人用, 而客户关系管理系统随时都有人用, 假设数据是通过页面提交的, 那这批数据到底该拒绝还是接受?
何时做Validation
通常有几个时机, 对象被创建出来, 对象状态改变, 以及对象被持久化. 企业应用中同一份数据一般至少有两种存在形式: 在数据库中的持久化状态, 以及在内存中以编程语言定义的对象形式存在. 那么几个时机:
手动创建对象, 就是应在构造函数中做验证
框架帮忙创建对象, 比如从页面Form绑定到Server端的对象时, 可以在绑定完成的那一刻做校验
存到数据库里那一刻

这就带来一个问题: 可能要在三个地方做大体相同的验证, 如何复用验证规则?另一个问题是: 在引入ORM的应用中, 编程语言写好的验证逻辑同样可以应用在持久化到数据库的那一颗, 那在SQL/DDL语句中定义的约束是否还必要?
如何表达错误
有两个约束:
要提供易于用户和支持人员理解的错误信息
要提供尽可能丰富的信息

常见的手段是用字符串或者错误代码/ID, 这是不work的, 因为它们合并了错误本身和错误的表示: 出错的地方可能距离需要展现错误的地方很远, 或者有多种展现错误的界面, 或者有很多显示方面的需求, 比如支持国际化, 报错的地方是没有能力也不需要知道错误是如何被展示的, 它要做的是尽可能报告关于错误的详细信息, 包括违反了什么规则, 出错的字段, 实际的值和期待的值等, 字符串和错误代码/ID是没有如此丰富的表达能力的我们可以用对象来表达错误信息, 对象的类型可以表示错误的类别, 对象的属性/字段可以携带各种与错误类型相关的数据. 然后在需要展现给用户的那一刻, 再把对象翻译成针对那个界面的显示, 比如可以做国际化, 或者提供给程序员更技术化的描述. 而在错误信息需要被显示之前, 错误在系统中的传递, 都是以对象的形式进行的...听起来跟异常Exception很像?几个反例是.Net平台上的异常, 比如KeyNotFoundException, 它就不告诉你那个找不到的Key是啥, 还有Index越界, 就不告诉你index的值是多少, 还有数据库连接超时或者Transaction Timeout,死活不告诉你它等了多久超时的, 让你搞不清楚是你的超时时间设的太短还是根本你的设置就没生效
如何传递错误
收集参数, 输出参数, Thread Local, 或者抛出异常然后合适的层次捕获
如何关联错误到发生错误的对象图, 尤其是对象图中非Root对象
给错误一个Key, 这个Key应该能表示出错的对象在对象图中的位置, 比如Key可以是字段名称中间用"."分隔, 级联起来的字符串. 注意这种形式的key应该是在调用验证逻辑的地方组装起来的, 而不应该是验证逻辑本身, 因为验证逻辑通常并不知道自己验证的这个对象在父对象中的字段名称
一个额外的话题

很多验证框架采用了基于Attribute/Anontation的方式, 这样当一个对象在不同的Context有不同的验证逻辑时就会很纠结, 因为它是以侵入的方式写到对象的定义中的. 这恰恰从另一个角度说明了对象是不应该跨Context复用的, DCI才是王道

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容