我的BO之强类型
我的BO
1-我的BO之强类型
2-我的BO之数据保护
3-我的BO之状态控制
4-我的BO之导航属性
弱类型的缺点
有些程序员对类型比较随意,从前端传来的数据,不管应该是什么类型,都以String
接收。然后在什么地方转成应该有的类型则要“看心情”,在Controller, Service, DA都有,甚至有从头到尾都不转为正确类型的。这里把一切都用String表示称为“弱类型”,相应地该是什么就是什么类型称为“强类型”。比如Service方法的参数清一色String
型的,其中的参数的位置传错了也发现不了。Long
,Date
型也是按String
在各层之间传送,若在DA层没有一个强有力的组件保障,很容易就被黑客SQL注入。有些中途要作运算,不得已转为强类型运算,然后因为下一级是弱类型,又转为弱类型继续传递。许多地方明明可以判断两个值是否相等,却因为类型不同需要先作转化,转化的过程又因为值是null
而出错,偏偏出错方面又没处理好,真是接连挖了几个坑等着人跳。
图:该是什么就是什么
正确的做法是用最正确的类型表示和传送每一个数据。至少在BO这一层,要完全强类型。
枚举类型
在DTO和数据库中,可能是String
,可能是Integer
,但对于BO来讲,它就只应该是枚举类型
。这样无疑对业务处理是最方便的。
日期时间类型
前后端交互时,出于方便调试的目的,我们采用字符串来表示,具体格式是yyyy-MM-dd HH:mm:ss
。 在DTO中体现为String
型,而在BO中则为Date
类型。
Java的Date
出现得早,受广泛各种组件的支持,但运算不方便,LocalDateTime
运算方便,但出现得晚,不受广泛支持。用Date
还是LocalDateTime
都算强类型。本来应该采纳运算方便的LocalDateTime
,但考虑到需要运算的可能性小,不需要运算的可能性大,若采用LocalDateTime
,就会增加不必的正反两次与Date
转化。最终决定两种类型同时支持,内部关联同一个数值。在需要运算时,读写LocalDateTime
型的属性时自动转化,在不需要运算时读写Date
型的属性则不会产生两次额外的转换。两种类型之间的转换由BO内部自动完成,外部使用时哪种类型方便就用哪种,十分方便。
强类型的优点:
- 防止SQL注入
- 方便运算
- 正确的取值范围
之前我的一篇文章推荐使用的7种基本数据类型讲到这方面。在数据库提供的很多种类型支持的情况下,我们也只挑战少数几种类型使用。在BO层则是以最贴切的类型来使用,并不局限于7种。比如BO中使用的枚举型,在数据库中往往表现为String
型或Integer
型。两者并不矛盾。
系列导航
博主简介:佘焕敏(shé),洋名 Billy Sir。
关注编程基础技术,并致力于研究软件的自动化生成。 对编程规范化、面向对象的极致使用也有着浓厚的兴趣。 同时非常希望能够写程序到65岁。
只有工匠精神,才能把常人觉得单调乏味的代码,当作作品雕刻成艺术品。
重点:这里几乎每一篇文章,都是我认真创作的,凝结了心血。写作从来都不是一件容易的事,对从小语文不好的我而言,是难上加难。而且,你发现没有,文中没有广告。这篇文章介绍了为什么要写这些文章。

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
2016-04-26 Ctrl-A全选这点事(C#,WinForm)