ASP.NET MVC 三层架构知识的学习总结

自从使用过一次MVC进行团队开发后,体会到了面向对象开发软件的便利。使用MVC的时候,各个层之间的低耦合使得他们之间的联系非常的第,也就降低了模块之间的依赖程度。

首先介绍一下MVC的意义,和各个层面之间的用途和功能。

1)实体层。主要用来声明在视图层和业务逻辑层之间传递数据的载体。通常代表来源与项目数据库中一个或者多个表组成的一条有意义的记录。

2)业务逻辑层。根据业务逻辑向视图层提供数据,这个项目中的类有权根据业务逻辑来决定是否调用数据库访问层的方法

3)数据库访问层。项业务逻辑层提供访问数据的方法。

4)视图层。主要是以网站开发为例。用于提供显示,添加,编辑和删除数据。

我在VS中创建的项目的结构图:

NetMVC就是所谓的视图层。Entity是实体层,用来声明开发过程中被要使用的所有变量。DAL是数据库访问层,主要完成所有操作对数据库的访问。BLL是业务逻辑层,处理视图层传来的业务逻辑,然后传递给数据库访问层进行处理。

本例主要演示的是登陆页面的实现,Entity层的代码如下

 
  1. usingSystem;
  2. usingSystem.Collections.Generic;
  3. usingSystem.Text;
  4. namespaceEntity
  5. {
  6. publicclassUserInfo
  7. {
  8. privateintUserId;
  9. ///<summary>
  10. ///用户比编号
  11. ///</summary>
  12. publicintUserId1
  13. {
  14. get{returnUserId;}
  15. set{UserId=value;}
  16. }
  17. privatestringusername;
  18. ///<summary>
  19. ///登录账户名称
  20. ///</summary>
  21. publicstringUsername
  22. {
  23. get{returnusername;}
  24. set{username=value;}
  25. }
  26. privatestringpassword;
  27. ///<summary>
  28. ///登录密码
  29. ///</summary>
  30. publicstringPassword
  31. {
  32. get{returnpassword;}
  33. set{password=value;}
  34. }
  35. privateintloginCount;
  36. ///<summary>
  37. ///登陆次数
  38. ///</summary>
  39. publicintLoginCount
  40. {
  41. get{returnloginCount;}
  42. set{loginCount=value;}
  43. }
  44. privateDateTimeregDate;
  45. ///<summary>
  46. ///注册时间
  47. ///</summary>
  48. publicDateTimeRegDate
  49. {
  50. get{returnregDate;}
  51. set{regDate=value;}
  52. }
  53. privateDateTimelastLoginDate;
  54. ///<summary>
  55. ///最后登录时间
  56. ///</summary>
  57. publicDateTimeLastLoginDate
  58. {
  59. get{returnlastLoginDate;}
  60. set{lastLoginDate=value;}
  61. }
  62. privateboolisForbidden;
  63. privatestringpasswordQuestion;
  64. ///<summary>
  65. ///找回密码提示问题
  66. ///</summary>
  67. publicstringPasswordQuestion
  68. {
  69. get{returnpasswordQuestion;}
  70. set{passwordQuestion=value;}
  71. }
  72. privatestringpasswordAnswer;
  73. ///<summary>
  74. ///找回密码答案
  75. ///</summary>
  76. publicstringPasswordAnswer
  77. {
  78. get{returnpasswordAnswer;}
  79. set{passwordAnswer=value;}
  80. }
  81. }
  82. }

完成对实体类的创建,接着就要完成对数据库访问层的创建(其中需要用到上篇问章所写的SqlHelper数据库访问通用类 http://yisuowushinian.blog.51cto.com/4241271/999324),代码如下,

 
  1. usingSystem;
  2. usingSystem.Collections.Generic;
  3. usingSystem.Text;
  4. usingSystem.Data;
  5. usingSystem.Data.SqlClient;
  6. usingSystem.Configuration;
  7. usingEntity;
  8. namespaceDAL
  9. {
  10. publicclassUserDal
  11. {
  12. privatestringconnectionString=ConfigurationManager.ConnectionStrings["connectionString"].ConnectionString;
  13. ///<summary>
  14. ///添加用户
  15. ///</summary>
  16. ///<paramname="info">用户的实体类</param>
  17. ///<returns></returns>
  18. publicboolAddUser(UserInfoinfo)
  19. {
  20. stringsql="insertintoUsers(Username,password)values('@Username','@password')";
  21. SqlParameter[]parameters=newSqlParameter[4];
  22. parameters[0]=newSqlParameter("@Username",SqlDbType.NVarChar,30);
  23. parameters[0].Value=info.Username;
  24. parameters[1]=newSqlParameter("password",SqlDbType.VarChar,50);
  25. parameters[1].Value=info.Password;
  26. returnnewSqlDbHelper(connectionString).ExecuteNonQuery(sql)>0;
  27. }
  28. ///<summary>
  29. ///删除用户
  30. ///</summary>
  31. ///<paramname="UserId">用户编号</param>
  32. ///<returns></returns>
  33. publicboolDeleteUser(intUserId)
  34. {
  35. stringsql="deletefromuserswhereUserId="+UserId;
  36. returnnewSqlDbHelper(connectionString).ExecuteNonQuery(sql)>0;
  37. }
  38. ///<summary>
  39. ///更新用户
  40. ///</summary>
  41. ///<paramname="info">用户的实体类</param>
  42. ///<returns></returns>
  43. publicboolUpDateUser(UserInfoinfo)
  44. {
  45. stringsql="updateuserssetpassword=@password,loginCount=@loginCountwhereuserid=@userid";
  46. SqlParameter[]parameters=newSqlParameter[7];
  47. parameters[0]=newSqlParameter("@password",SqlDbType.VarChar,30);
  48. parameters[0].Value=info.Password;
  49. parameters[1]=newSqlParameter("@loginCount",SqlDbType.Int,4);
  50. parameters[1].Value=info.LoginCount;
  51. returnnewSqlDbHelper(connectionString).ExecuteNonQuery(sql)>0;
  52. }
  53. ///<summary>
  54. ///根据用户名或者用户编号查询用户
  55. ///</summary>
  56. ///<paramname="userId">用户编号</param>
  57. ///<returns></returns>
  58. publicDataTableGetUser(intuserId)
  59. {
  60. stringsql="select*fromuserswhereuserId=@UserId";
  61. SqlParameter[]parameters=newSqlParameter[1];
  62. parameters[0]=newSqlParameter("@UserId",SqlDbType.Int,4);
  63. parameters[0].Value=userId;
  64. returnnewSqlDbHelper(connectionString).ExecuteDataTable(sql,CommandType.Text,parameters);
  65. }
  66. ///<summary>
  67. ///根据用户名查询用户信息
  68. ///</summary>
  69. ///<paramname="Username">用户名</param>
  70. ///<returns></returns>
  71. publicDataTableGetUser(stringUsername)
  72. {
  73. stringsql="select*fromuserswhereusername=@username";
  74. SqlParameter[]parameters=newSqlParameter[1];
  75. parameters[1]=newSqlParameter("@username",SqlDbType.NVarChar,30);
  76. parameters[1].Value=Username;
  77. returnnewSqlDbHelper(connectionString).ExecuteDataTable(sql,CommandType.Text,parameters);
  78. }
  79. ///<summary>
  80. ///按照用户编号升序查询从指定位置开始的指定条数记录
  81. ///</summary>
  82. ///<paramname="startIndex">查询的起始位置</param>
  83. ///<paramname="size">返回的最大记录条数</param>
  84. ///<returns></returns>
  85. publicDataTableGetUserList(intstartIndex,intsize)
  86. {
  87. stringsql="selecttop"+size+"*fromuserswhereUserIdnotin(selecttop"+startIndex+"UserIdfromUsersorderbyUserIdasc)orderbyUserIdasc";
  88. returnnewSqlDbHelper(connectionString).ExecuteDataTable(sql);
  89. }
  90. ///<summary>
  91. ///查询用户总数
  92. ///</summary>
  93. ///<returns></returns>
  94. publicintGetUserCount()
  95. {
  96. stringsql="selectcount(1)fromUsers";
  97. returnint.Parse(newSqlDbHelper(connectionString).ExecuteScalar(sql).ToString());
  98. }
  99. }
  100. }

然后创建业务逻辑层,代码如下:

 
  1. usingSystem;
  2. usingSystem.Collections.Generic;
  3. usingSystem.Text;
  4. usingDAL;
  5. usingEntity;
  6. usingSystem.Data;
  7. usingSystem.Data.SqlClient;
  8. usingSystem.Security.Cryptography;
  9. usingSystem.Security;
  10. namespaceBLL
  11. {
  12. publicclassUserBLL
  13. {
  14. privatestaticstringMD5Hash(stringpassword)
  15. {
  16. MD5md5=MD5.Create();//创建Md5算法实例
  17. //将原始字符串转换成UTF-8编码的字节数组
  18. byte[]sourceBytes=System.Text.Encoding.UTF8.GetBytes(password);
  19. //计算字节数组的哈希值
  20. byte[]resultBytes=md5.ComputeHash(sourceBytes);
  21. StringBuilderbuffer=newStringBuilder(resultBytes.Length);
  22. //将计算得到的哈希值的字节数组中的每一个字节转换成十六进制形式
  23. foreach(bytebinresultBytes)
  24. {
  25. buffer.Append(b.ToString("X"));
  26. }
  27. returnbuffer.ToString();
  28. }
  29. ///<summary>
  30. ///添加用户
  31. ///</summary>
  32. ///<paramname="info">用户的实体类</param>
  33. ///<returns></returns>
  34. publicstaticboolAddUser(UserInfoinfo)
  35. {
  36. UserDaldal=newUserDal();
  37. DataTabledata=dal.GetUser(info.Username);
  38. if(data.Rows.Count>0)
  39. {
  40. returnfalse;
  41. }
  42. else
  43. {
  44. info.Password=MD5Hash(info.Password);
  45. returnnewUserDal().AddUser(info);
  46. }
  47. }
  48. ///<summary>
  49. ///删除用户
  50. ///</summary>
  51. ///<paramname="userId">用户编号</param>
  52. ///<returns></returns>
  53. publicstaticboolDeleteUser(intuserId)
  54. {
  55. returnnewUserDal().DeleteUser(userId);
  56. }
  57. ///<summary>
  58. ///更新用户
  59. ///</summary>
  60. ///<paramname="info">用户的实体类</param>
  61. ///<paramname="changePassword">是否需要对用户密码进行加密</param>
  62. ///<returns></returns>
  63. publicstaticboolUpdateUser(UserInfoinfo,boolchangePassword)
  64. {
  65. //如果更改密码就需要对新密码进行加密
  66. //如果没有更改密码则不能对密码重复加密,否则会对用户造成无法登陆
  67. if(changePassword)
  68. {
  69. info.Password=MD5Hash(info.Password);
  70. }
  71. returnnewUserDal().UpDateUser(info);
  72. }
  73. ///<summary>
  74. ///根据用户编号查询用户
  75. ///</summary>
  76. ///<paramname="UserId">用户的编号</param>
  77. ///<returns></returns>
  78. publicstaticDataTableGetUser(intUserId)
  79. {
  80. returnnewUserDal().GetUser(UserId);
  81. }
  82. ///<summary>
  83. ///根据用户名查询用户信息
  84. ///</summary>
  85. ///<paramname="userName">用户名</param>
  86. ///<returns></returns>
  87. publicstaticDataTableGetUser(stringuserName)
  88. {
  89. returnnewUserDal().GetUser(userName);
  90. }
  91. ///<summary>
  92. ///按照用户编号升序查询从指定位置开始的指定条数的记录
  93. ///</summary>
  94. ///<paramname="startIndex">查询的起始位置</param>
  95. ///<paramname="size">返回的最大记录条数</param>
  96. ///<returns></returns>
  97. publicstaticDataTableGetUserList(intstartIndex,intsize)
  98. {
  99. returnnewUserDal().GetUserList(startIndex,size);
  100. }
  101. ///<summary>
  102. ///查询用户总数
  103. ///</summary>
  104. ///<returns></returns>
  105. publicstaticintGetUserCount()
  106. {
  107. returnnewUserDal().GetUserCount();
  108. }
  109. ///<summary>
  110. ///根据用户名或者用户编号从数据库查询对应记录的实体,如果不存在则返回null
  111. ///</summary>
  112. ///<paramname="userId">用户编号</param>
  113. ///<returns></returns>
  114. publicstaticUserInfoGetUserEntity(intuserId)
  115. {
  116. returnChangeToEntity(newUserDal().GetUser(userId));
  117. }
  118. ///<summary>
  119. ///根据用户名或者用户编号从数据库查询对应记录的实体,如果不存在则返回null
  120. ///</summary>
  121. ///<paramname="userName">用户名</param>
  122. ///<returns></returns>
  123. publicstaticUserInfoGetUserEntity(stringuserName)
  124. {
  125. returnChangeToEntity(newUserDal().GetUser(userName));
  126. }
  127. ///<summary>
  128. ///将包含Users表记录的DataTables中的第一条记录转换成Userinfo实体
  129. ///</summary>
  130. ///<paramname="data"></param>
  131. ///<returns></returns>
  132. privatestaticUserInfoChangeToEntity(DataTabledata)
  133. {
  134. UserInfoinfo=null;
  135. //如果data不为空并且包含的记录条数大于0、
  136. if(data!=null&&data.Rows.Count>0)
  137. {
  138. DataRowrow=data.Rows[0];
  139. info=newUserInfo();
  140. }
  141. returninfo;
  142. }
  143. publicstaticboolLogin(stringuserName,stringpassword)
  144. {
  145. boolexits=false;
  146. UserInfoinfo=GetUserEntity(userName);
  147. if(info!=null&&MD5Hash(password)==info.Password)
  148. {
  149. exits=true;
  150. info.LoginCount=info.LoginCount+1;//将用户登陆的次数加1
  151. info.LastLoginDate=DateTime.Now;//将用户最后的登录时间设置为现在
  152. UpdateUser(info,false);//更新用户的登陆次数和最后的登录时间
  153. }
  154. returnexits;
  155. }
  156. }
  157. }

这个就完成了对数据库访问层,实体层,业务逻辑层的创建工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值