zoukankan
html css js c++ java
多层的一个框 架
宝贝记个性签名系统架构分析
这个签名系统采用了三层架构,见下图
图片附件
:
绘图4.gif
(2006-10-26 23:50, 5.92 K)
数据实体层
对应MYSQL数据库里面的表结构,每个数据实体存储的就是一条记录。
数据访问层
封装了对数据库的访问操作,包括增删修改,调用存储过程,把取出的记录构造成数据实体,返回给业务逻辑层。
业务逻辑层
封装了对数据的一些逻辑操作过程。
Web应用层
包含了页面显示的aspx文件和处理数据输入输出的cs文件。
我使用了VS2005来开发这个系统,因为系统很小,所以采用了VS2005的SiteApplication开发模型,原则上每一层都应该有一个独立的工程Project,但是因为系统较小,我都放到了同一个Project里面,而采用不同的目录来划分这几层。
见下图
图片附件
:
未命名.gif
(2006-10-26 23:50, 23.89 K)
Component是我实现的组件类,主要是实现的计划任务,每天定时更新生成签名图片。IJob是一个接口类,GenerateImageJob是实现这个接口的具体类,Jobs负责来调度这些GenerateImageJob等不同的Job,当然我的系统里现在只有一种Job,以后要增加不同功能的计划任务的话,只要设计一个实现IJob接口的类就可以了。
Code.aspx和Default.aspx属于Web应用层,我们能访问到的也就是这两个页面,可能有的人觉得一共就两个页面有必要搞那么多层吗?可能小系统看不出太大的好处来,但是系统一大,优点就很明显了。
比如我们更换了数据库,比如MySQL换成了SQL,那我们只要修改数据访问层就可以了,其他几层都不用修改。而且我还可以使用数据适配器工厂和数据访问接口来同时支持多个不同类型的数据库。
如果我们的一些业务逻辑发生了,只要修改业务逻辑层即可。
如果要修改页面层呈现方式,只要修改aspx页面即可。
每一层都专注于某个方面的功能实现,这样系统修改和维护就非常方便,而且大的系统还可以有不同的人同时来实现不同的层,比如美工负责页面显示,业务专家实现业务逻辑层,数据访问层由数据库管理员来实现。
看Discuz的代码可以发现,它的系统里面只是实现了页面显示和代码的分离,也就是和.NET里面的aspx和cs文件关系差不多,没有实现面向对象的分层机制,所以把数据库访问和逻辑操作都混杂在php文件里面,修改、二次开发和制作模版都不是很方便。
相对来说我更喜欢.NET一些,C#语法优美,程序运行性能好,用VS2005开发效率也比较高,而且.NET2.0里面包含了更多强大的功能,包括换肤,国际化,用户管理等等。
当然php也有它的优点,语法简洁,比较灵活,运行效率也还不错,在unix系统上比较流行。
世界上没有最完美的程序语言,任何语言都有利有弊。语言只是一种工具,针对不同的问题,选择最适合自己的语言来开发才是王道。
而且任何问题也不是只有一种解决方法,不同的情况有不同的解决方案,要辩证地看待问题,选择合理适合的解决方案。
扯远了,呵呵
查看全文
相关阅读:
webpack打包提示: Uncaught Error: Cannot find module 'strip-ansi'
CentOS 7.6 内网穿透服务lanproxy部署
《这是全网最硬核redis总结,谁赞成,谁反对?》六万字大合集
网络监控解决方案及拓扑图
漫画:什么是 “混合云”?
听说过Paas、Saas和Iaas,那你听说过Apaas吗?
Squid设置用户名密码
别再售卖 5块钱 的 Win10 激活码了,后果很严重
Jackson 实体转Json、Json转实体
Spring
原文地址:https://www.cnblogs.com/fuyingke/p/561280.html
最新文章
选择排序
Shell:命令
悲观地储蓄,乐观地投资
Scrum转型(三) Scrum工件
IDEA常用快捷键汇总
VsCode常用快捷键汇总
虚拟内存
变量的作用域
一文说清C#的快捷键
运动控制卡,越来越简单了
热门文章
推荐7个工具网站,你要不要?
这样学上位机,是不是有意思多了
用Zebra打印机制作一个节日贺卡
远程访问本地数据库部署指南
五大通信库,围攻莫迪康
Zmotion快速入门之EtherCAT通信
关于“skip-name-resolve”的一个问题
如何避免微服务设计中的耦合问题
平衡
边缘认证和与令牌无关的身份传播
Copyright © 2011-2022 走看看