ASP.NET三层设计模型详解

来源:互联网 发布:黑道圣徒2优化补丁 编辑:程序博客网 时间:2024/05/22 01:47

ASP (Active Server Page) 的功能:

  可以把VBScript 编写的服务器端脚本嵌入到Web页面中, 在服务器端动态生成页面内容;

  可以通过COM 组件与数据库连接, 从而提供强大的事务处理功能。

  ASP的缺点:

  (1) 由于用脚本语言编写的控制逻辑要嵌入到HTML标记中, 因此ASP页面的开发效率低, 后期维护困难;

  (2) 动态部分采用脚本语言编写, 其功能受到限制, 不利于开发复杂的程序;

  (3) 程序员要自己维护页面之间数据的传递工作;

  (4) ASP技术很难采用面向对象的思路和方法来开发程序;

  关于ASP.NET

  可以采用WebForm编程模型, 该模型由底层系统自动完成客户(Client) 和服务器(Server) 之间繁琐的交互, 而且还提供了状态管理功能, 能在不同页面请求之间自动维护页面数据。

  关于B/S 结构

  与传统的C/S (Ciient/Server) 结构不同, B/S 结构中的大部分功能都在服务器端实现。服务器根据用户浏览器发送的请求, 在进行相应的运算和处理后, 向用户浏览器发送Web页面, 页面由标准的HTML 文本和Javascript 客户端脚本构成。

  ASP.NET的三层开发设计模型

  分层模型的优点:

  每一层只实现相对独立的功能,当任何一层发生变化时, 只要保持层间接口关系不变, 则其它各层都不会受到影响。

  (1) 用户界面层 (User Interface Tier):

  显示由业务逻辑层动态传送的数据信息,并通过使用相应的HTML 标记和CSS (Cascade Style Sheet) 模式来实现。同时还要负责用户录入数据的获得和校验,并传送给业务逻辑层。

  (2) 业务逻辑层 (Business Logic Tier):

  为用户界面层提供功能调用, 同时它又调用数据访问层所提供的功能来访问数据库。还要根据系统设计, 构造工程中关键的几个对象, 实现工程中的大部分逻辑控制功能。

  (3) 数据访问层 (Data Access Tier):

  主要用来实现与数据库的交互, 即完成查询、插入、删除和修改的功能。它根据业务逻辑层的要求,从数据库中提取或修改数据。访问数据库是系统中最频繁、最消耗资源的操作, 所以要优化对数据库的访问, 提高系统的性能和可靠性。

  BBS 工程实例

  整个工程被划分为四个功能模块:

  目录管理(Directory):采用“树”结构实现;

  文章管理(Article):文章存放在相应的目录下;

  用户管理(User):对用户的管理和授权;

  权限管理(Right):授权细化到各级目录和每篇文章;

  系统采用SQL Server 2000 Enterprise 数据库,Visual Studio开发工具和C#语言。

  整个工程为一个“方案”(solution),而分层模型中的每一层都对应为一个“项目”(Project),每个项目都对应各自的“名字空间”(Namespace),各个项目都从属于方案。

  本工程中包括四个项目,其中的Web、BussinessFacade 和DataAccess 项目分别对应设计模型的三个层次,还有一个项目Common用于定义层间的数据接口。结构如图所示:

  

  (1) Web 项目

  Web 项目与“用户界面层”对应,在这一层中,每个WebForm 页面显示部分存放在aspx文件中。

  (2) BusinessFacade 项目

  BusinessFacade 项目与“业务逻辑层”对应,在这一层中包括对四个“类”的定义:

  DirectorySystem、ArticleSystem、UserSystem 和 RightSystem,它们对应于系统的四大功能。

  例如在RightSystem 类中就提供了:

  用于目录权限鉴别的CheckDirectoryRight 方法;

  用于过滤目录列表的FilterDirectoryList 方法;

  用于用户授权的AuthorizeUser 方法;

  以及其它一些用于权限管理的成员函数,这些成员函数可以在用户界面层中直接调用。

  在这一层中要引入DataAccess 项目的名字空间, 从而使用该项目提供的功能实现对数据库的访问。

  (3) DataAccess 项目

  DataAccess 项目与“数据访问层”对应,在这一层中也包括四个“类”的定义:

  DirectoryAccess、ArticleAccess、UserAccess 和RightAccess.每个类的成员函数都是根据业务逻辑层的要求来访问SQL Server 中相应的存储过程(Stored Procedure)。

  例如: 在ArticleAccess 类中的LoadDetailByID 方法,就是用来调用SQL Server 中的GetArticleDetailByIDStatus 存储过程,从而实现通过文章的ID和状态得到文章的详细信息。

  在CLR 平台上进行。net 编程,一般由系统的垃圾收集机制(Garbage Collect)来消除不再使用的对象。但由于访问数据库将会消耗大量的系统资源, 所以这一层的四个类都派生自 System.IDisposable 接口(使用using 语句引用),使得在不使用本层对象的时候及时释放掉所占用的资源。

  (4) Common 项目

  为了使得各层之间在传递数据时具有统一的数据接口,在三个层次对应的项目之外又开发了一个Common 项目。在这个项目中定义了四个类:

  DirectoryData、AricleData、UserData 和RightData.这些类都派生自System.Data.DataSet 类,在每个DataSet 中定义了一些DataTable 用来按照固定的格式存储相应的数据。

  对于Web、BusinessFacade 和DataAccess 项目中定义的类, 其成员函数的参数和返回值的类型就可以采用Common 项目中定义的类, 这些类就是不同层之间数据传送的标准接口。

  附加代码:

  在ASP.NET 支持下,利用ADO.NET 可方便地访问基于Web 的数据库,不管数据源是关系数据库、非结构的数据库、文字数据库(如XML文件),还是如Microsoft Excel 一样的表格数据库,都可通过ADO.NET来存取。

  在实现远程数据库时,需要将ADO 与RDS 集成使用,以实现高性能、高可靠性的远程操作功能。

  DataGrid 控件的更新Code 如下:

  控件的更新Code 如下:

 void editcommand (Object sender, DataGridCommandEventArgs e)
  {
  grid1.EditItemIndex = (int)e.Item.ItemIndex;
  //重新读取数据并进行绑定
  bindgrid();
  }
  void Cancelcommand (Object sender, DataGridCommandEventArgs e)
  {
  grid1.EditItemIndex = -1;
  //重新读取数据并进行绑定
  bindgrid();
  }
  void updatecommand (Object sender ,DataGridCommandEventArgs e)
  {
  //利用Sql 语句实现数据的更新
  string xm = grid1.DataKeys[(int)e.Item.ItemIndex];
  string[] cols[4];
  int numcols = e.Item. Cells.Count;
  for (int i = 2; i < numcols; i++)
  {
  //取出各编辑框的值
  String colvalue = ((TextBox)e.Item.Cells[i].Controls[0]).Text;
  cols[i-2] = colvalue ;
  }
  string updatecmd ="UPDATE reg SET name ='"+ cols[0 ] +"',";
  updatecmd +="sex ='"+ cols[1] +"',addr ='"+ cols[2] +"',";
  updatecmd +="dh ='"+ cols[3] +"' where name =" + xm;
  SqlCommand mycommand = new SqlCommand(updatecmd, myconnection);
  mycommand.Connection.Open(); //打开数据连接
  mycommand.ExecuteNonQuery(); //执行连接
  grid1.EditItemIndex = -1; //连接成功,返回初始状态
  mycommand.Connection.Close(); //关闭连接
  bindgrid(); //重新读取数据并绑定
  }
  void bindgrid()
  {
  //数据绑定
  SqlDataAdapter mycommand = new SqlDataAdapter("select * from reg", myconnection);
  DataSet ds = new DataSet();
  mycommand.Fill(ds,"reg");
  grid1.DataSource = ds.Tables["reg"].DefaultView;
  grid1.DataBind();
  }

原创粉丝点击