• 三层架构实例


    三层架构实例

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

    原文://http://blog.csdn.net/xjc1278003262/article/details/8867177

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

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



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


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


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


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


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



    二、引用(关键步骤)

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

    引用步骤一:


    引用步骤二:


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


    三、各层实现代码如下

    B层代码

    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层代码

    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层代码

    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. }  


    实体层代码

    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. }  


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



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

  • 相关阅读:
    ASP.NET页面打印技术的总结
    js传递中文参数的url到asp(jscript)解释得到的中文参数为乱码的解决方法
    header的用法(PHP)
    oracle 11g road(/dev/shm需注意)
    mysql 主从同步 Error 'Out of range value for column的问题
    linux shell 过滤特殊字符开始的行
    Oracle穿越incarnation恢复数据
    多普达A6388刷机2.3
    【忽悠普通人用】隐藏文件夹的方法
    电脑同时使用双网卡实现方法
  • 原文地址:https://www.cnblogs.com/dingfangbo/p/5769526.html
Copyright © 2020-2023  润新知