三层架构实例

三层架构实例

一、新建立一个三层架构体系结构解决方案

新建一个空白解决方案。然后:    

1.“添加”-“新建项目”-“Visual C#”-“类库”-“称:LoginBLL”-“业务逻辑”(业务层,下简称B层)如下图:

三层架构实例_第1张图片


 2.“添加”-“新建项目”-“Visual C#”-“类库”-“名称:LoginDAL”-“数据访问”(数据层,下简称D层)如下图:

三层架构实例_第2张图片


3.“添加”-“新建项目”-“Visual C#”-“类库”-“名称:LoginUI”(界面层,下简称U层)如下图:

三层架构实例_第3张图片


U层的界面效果图:如下图

三层架构实例_第4张图片

 4. “添加”-“新建项目”-“Visual C#”-“类库”-“名称:LoginModel”(以下实体层)如下图:

三层架构实例_第5张图片

三层建立后的效果图,如下图:

三层架构实例_第6张图片


二、引用(关键步骤)

右键点“解决方案”-“添加引用”,设置U依引用D、B,B引用于D。对U添加引用D、B,对B添加引用D。如下图:

引用步骤一:

三层架构实例_第7张图片

引用步骤二:

三层架构实例_第8张图片


到此为止,一个登录的三层架构的建立起来了。


三、各层实现代码如下

B层代码

[csharp] view plain copy print ?
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6. using Login.BLL;  
  7. using Login.DAL;  
  8. using Login.Model;  
  9. namespace Login.BLL  
  10. {  
  11.     public class LoginManager  
  12.     {  
  13.         public UserInfo UserLogin(string userName, string password)  
  14.         {  
  15.   
  16.             UserDAO uDao = new UserDAO();  //实例化D层的类  
  17.             UserInfo user = uDao.SelectUser(userName, password); //将user信息传递给D层  
  18.             if (user == null)  //判断user信息  
  19.             {  
  20.                 throw new Exception("登陆失败");  
  21.             }  
  22.             else  
  23.             {  
  24.                 return user;  
  25.             }  
  26.   
  27.   
  28.         }  
  29.     }  
  30. }  

D层代码

[csharp] view plain copy print ?
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6. using Login.Model;  
  7. using System.Data.SqlClient;  
  8. using System.Data;  
  9.   
  10. namespace Login.DAL  
  11. {  
  12.     public class UserDAO  
  13.     {  
  14.          //连接数据库  
  15.         public static string ConnString = @"Server=XJC-PC; Database=chargeStudent; User ID=sa; Password=123456";  
  16.          
  17.         public  UserInfo SelectUser(string userName, string password) //各层都要用到实体类userInfo 通过实体类连接  
  18.   
  19.         {  
  20.               
  21.             using (SqlConnection conn = new SqlConnection(ConnString))  
  22.             {  
  23.                 SqlCommand cmd = conn.CreateCommand(); //数据库连接命令  
  24.                 cmd.CommandText = @"select * from user_Info where user_Name=@userName AND user_PWD=@password";  
  25.                 cmd.CommandType = CommandType.Text;  
  26.                 cmd.Parameters.Add(new SqlParameter("@userName", userName));  
  27.                 cmd.Parameters.Add(new SqlParameter("@password", password));  
  28.                 conn.Open();  
  29.                 SqlDataReader reader = cmd.ExecuteReader();  //读取数据  
  30.                 UserInfo user = new UserInfo();  
  31.                 while (reader.Read())  
  32.                 {  
  33.                       
  34.                     user.userName = reader.GetString(0);  
  35.                     user.password = reader.GetString(1);  
  36.                      
  37.                 }  
  38.                   return user;  
  39.             }  
  40.             
  41.         }  
  42.   
  43.     }  
  44. }  

U层代码

[csharp] view plain copy print ?
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.ComponentModel;  
  4. using System.Data;  
  5. using System.Drawing;  
  6. using System.Linq;  
  7. using System.Text;  
  8. using System.Threading.Tasks;  
  9. using System.Windows.Forms;  
  10. using System.Data.SqlClient;  
  11. using Login.BLL;  
  12. using Login.Model;  
  13. namespace LoginUI  
  14. {  
  15.     public partial class Form1 : Form  
  16.     {  
  17.         public Form1()  
  18.         {  
  19.             InitializeComponent();  
  20.         }  
  21.   
  22.         private void btnLogin_Click(object sender, EventArgs e)  
  23.         {  
  24.             LoginManager mgr = new LoginManager(); //实例化B层的类  
  25.             string userName = txtUserName.Text.Trim();  
  26.             string Password = txtPassword.Text;  
  27.             UserInfo user = mgr.UserLogin(userName, Password);   //将user信息传递给B层    
  28.             MessageBox.Show("登陆用户:" + userName);  
  29.         }  
  30.     }  
  31. }  


实体层代码

[csharp] view plain copy print ?
  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Linq;  
  4. using System.Text;  
  5. using System.Threading.Tasks;  
  6.   
  7. namespace Login.Model  
  8. {  
  9.     public class UserInfo  
  10.     {  
  11.         public string userName;  
  12.         public string UserName  
  13.         {  
  14.             get { return userName; }  
  15.             set { userName = value; }  
  16.         }  
  17.         public string password;  
  18.         public string PassWord  
  19.         {  
  20.             get { return password; }  
  21.             set { password = value; }  
  22.         }  
  23.     }  
  24. }  

四、运行成功的结果图:如下图

三层架构实例_第9张图片


以上是我对“三层实例”的真是实现,如有不妥之处,还请指教。

你可能感兴趣的:(分层与MVC实践)