如何在ASP.NET中使用三层架构

   学ASP.NET都知道它的最经典的架构是三层架构,也是目前应用得最广泛的一种架构.以前说起三层架构大家都知道MVC架构,这是html开发中用得比较多的,现在AJAX主要就是用这种架构。大家ASP.NET的三层是指数据访问层,业务逻辑层和表示层,而且都知道数据访问层是用来访问数据的,业务逻辑层是用来处理一些系统的业务逻辑的,表示层就是把内容呈现出来给用户,与用户进行交互的。划分三层的好处就是每一层都是独立的,修改其中一层一般不会影响其他层的代码,这样就大大的方便了日后的维护和升级。它最大的缺点是架构和编码都比较复杂,而且对性能的提高没有任何帮助,反而还可能会降低执行效率。

  有时候真的觉得“三层”编起来挺麻烦的,在ASP.NET 2.0里,访问数据和显示出来只要拖两个控件就可以了(AccessDataSource/SQLDatasource和GridView),几分钟一个页面就出来了,而且还具备了修改中,删除,分页,排序等功能。而用三层架构就麻烦多了,先要写数据访问层的代码,接着写业务逻辑层的代码(要调用数据层的方法),最后才是表示层,也就是页面的设计,还有调用业务逻辑层的代码读取数据。(注意:表示层是绝对不会访问数据层的内容,只能通过业务层。业务层在这里是连接它们的桥梁。所以说业务层是最重要的一层)既然这样为什么还要用三层呢?前面提到的一层架构的一个很大的问题就是前台和后台代码没有很好的分开,不利于分工,第二,不利于日后的维护和升级。如果是个人主页或者是一些一个人完成的小系统用一层还是挺方面的。如果是一些比较大的系统,特别是企业级的应用,就非用三层甚至n层不可了。一般三层就很够了,再划分更多只会增加设计和编码的难度。

  那到底怎么去分层呢?怎么样分层就符合三层架构原则呢?这是很多刚入门的人经常问的问题。我翻了很多本案例书,可惜很多都是一层或者是两层架构的,绝少三层的。后来研究了petshop4.0和下了一些国外的资料来看才开始对如何分层有点了解。我总结了一下主要有以下三种分层方式:

  一:数据层不包含任何代码,只有数据库,还有相关的存储过程。

  这种模式下,数据层看起来就变得很简单了。只包含你建立的数据库,和一些存储过程(注意是存储过程)。其实这些存储过程的建立也是相当复杂的(我以后会专门写一篇这方面的文章),因为它们可以完成除数据访问外的其他一些很强大的功能,如分页,实现搜索算法等。数据访问的逻辑就都放在业务层,当然业务层还包含其他一些逻辑代码。我们来看一个示例,假设数据库里有一个表BOOKS(书),建立一个存储过程GetAllBooks,用来读取书的信息,这样在业务层里编一个方法GetBookS()和一个公用数据库访问类,GetBooks()就通过数据库访问类打开连接,执行在存储过程,返回数据(返回类型可以是DataTable,DataSet,DataReader或者实体类)。业务层单独编译成一个或者几个DLL文件。接着就是表示层了,表示层通过调用GetBookS()返回数据绑定在相关的控件里。务层的方法都是在表示层调用。一般来说book.aspx和book.aspx.cs都是表示层的内容。所有前台的设计,相关控件,数据缓存都是属于表示层。

  二:数据层还包含所有公共数据访问代码。

  这种模式和前一种差别不大,主要是把数据访问代码六到数据层。这样可以很方面实现对多数据库的支持。业务逻辑层直接调用数据层的相关访问数据的代码,完全不必了解底层是什么数据库。其他和前一种没什么分别。

  三:所有数据读取都放在数据层。

  这种模式下像前面所述的GetBooks()方法都是放在数据层,在业务层再定义一个GetBookS()方法以供表示层调用。这种模式下业务层不但不必了解底层是什么数据库,而且连数据库的结构都不必了解了。这可以说是最标准的三层架构了,在Microsoft的PetShop 4.0里就是用这种模式。

  以上就是我总结的一些内容,可能不是很准确,请大家多多指教。

时间: 2024-10-29 16:15:30

如何在ASP.NET中使用三层架构的相关文章

asp 表 select-统计表数据后如何在asp页面中显示呢

问题描述 统计表数据后如何在asp页面中显示呢 3.需要一张表,包括:每种产品的销售数量汇总.两列分别为:productid,total_quantity select productid,sum(quantity) as total_quantity from [order details] group by productid 如何将这个表在asp中显示呢,表中既有产品名也有数量.我是菜鸟,可以帮帮我吗 解决方案 用join啊,在gridview那里的sql语句生成器你点点不就好了.简直好用

如何在asp.net中插入Flash动画(!!!)

问题描述 如何在asp.net中插入Flash动画有人告诉我插入object标记,但是我在Dreamweaver中插入flash,把代码直接粘进去,(确实有object标记),但是浏览时无法显示 解决方案 解决方案二:我写了一个:<%@PageLanguage="C#"%><!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1

如何在asp.net中对表单进行有选择的验证

问题描述 如何在asp.net中对表单进行有选择的验证,最好是VBscrip的,哪位能给指点一下,谢谢! 解决方案 解决方案二:无语解决方案三:我的意思是我在同一个页面上有2个提交按钮,每个提交按钮都分别要对不同的控件进行验证,怎样才能实现呢?

如何在ASP.NET中生成HTML5离线Web应用

传统的Web应用程序有一个很大的症结是当用户的网络连接不好时,应用会加载失败,为了 解决这一问题,HTML5中引入了Web的离线工作的功能.离线功能使得Web应用程序类似于本机应用程序,当断开网络连接时可以继续浏览未浏览完成的内 容,离线功能的另一个好处是可以永久缓存静态的内容,而没有缓存过期的限制,这样很大程度上加速了网页的加载速度. 离线应用的创建 不同于传统的缓存机制,HTML5定义了一套独立的缓存机制,有一个单独的文件来记录要缓存的文件列表,这就意味着用户可以自己决定哪些文件需要缓 存.

如何在ASP.NET中使用SmtpMail发送邮件

在ASP中,就可以通过调用CDONTS组件发送简单邮件,在ASP.NET中,自然也可以.不同的是,.Net Framework中,将这一组件封装到了System.Web.Mail命名空间中. 一个典型的邮件发送程序如下: <%@ Import Namespace="System.Web.Mail" %> <script runat="server"> MailMessage mail=new MailMessage();  mail.From

如何在ASP程序中使用Telnet协议

程序 1 设计背景 越来越多的企业在建立自己的WEB站点时选择了基于微软的构架.Windows操作系统.IIS WEB Server和ASP技术得到了广泛的使用.但很多企业的网络中存在大量的UNIX主机,导致我们经常希望在浏览器中实现对UNIX系统资源的访问和控制,例如:通过浏览器查看UNIX系统中的用户进程.查看网络状态.甚至完成杀死一个进程这样的控制操作.以前我们可以通过Telnet程序远程登录到UNIX主机上,输入用户名和口令,并在命令行方式下输入命令.通过ASP中的ActiveX控件编程

如何在ASP.Net 中把图片存入数据库

asp.net|数据|数据库 介绍 可能有很多的时候,我们急需把图片存入到数据库当中.在一些应用程序中,我们可能有一些敏感的资料,由于存储在文件系统(file system)中的东西,将很容易被某些用户盗取,所以这些数据不能存放在文件系统中. 在这篇文章中,我们将讨论怎样把图片存入到Sql2000当中. 在这篇文章中我们可以学到以下几个方面的知识: 1. 插入图片的必要条件 2. 使用流对象 3. 查找准备上传的图片的大小和类型 4.怎么使用InputStream方法? 插入图片的必要条件 在我

如何在Asp.net中使用HtmlArea编辑器

HtmlArea是一款很简洁的WTYSWTYG编辑器,以前我用的是FreeTextBox,缺点 很多,运行速度慢,架构太复杂,不支持ajax等等,前面还特地写了一篇文章< Ajax中的UpdatePanel与Freetextbox兼容问题的初步解决方法>,现在终于痛下 决心砍了. HtmlArea是纯JS+Html的编辑器,理论上可以套在任何语言平台上,经过实际 使用可以和Asp.Net 2.0 + Ajax 很好的结合,现在本博客系统已经拿它当作文 章编辑器了,下面就是具体安装步骤. 首先下

如何在 ASP.NET 中下载文件

这是笔者常被问到的一个问题,如何通过ASP.NET来下载文件,这个问题可大可小,我们先从小的开始. 这是笔者常被问到的一个问题,如何通过ASP.NET来下载文件,这个问题可大可小,我们先从小的开始.当我们要让用户下载一个文件,最简单的方式是通过Response.Redirect指令: Response.Redirect("test.doc") 您可以把上面这行指令放在Button的Click事件当中,当用户点击按钮之后,网页就会被转址到该word档,造成下载的效果. 但是这样的下载有几