有史以来最简单的三层实例(C#) ——转载自CSDN

阅读: 评论:0

有史以来最简单的三层实例(C#)  ——转载自CSDN

有史以来最简单的三层实例(C#) ——转载自CSDN

三层已经学了很久了,一直没有写博客是因为自己感觉对三层的理解还太肤浅,怕写的不对误导别人。当然就现在我的水平而言对于三层的理解还是不够深刻,但是我感觉不至于误导别人了,所以将我对于三层的一些理解写出来,希望会对和我当初一样迷茫的菜鸟一些帮助!

 

回想当初我学习三层的时候,在网上寻找关于三层的知识,找到了很多例子,但是感觉它们都有些复杂,不太适合刚刚接触三层的人学习,所以我决定写一个简单的三层实例,下面言归正传。

 

简单的三层划分:

 

 

用户登录界面:

 

 

用户名、密码输入正确以后提示登录成功:

 

 

下面是UI层的代码:

 

[csharp] view plain copy print ?
  1. //单击登录按钮   
  2.         private void btnLogin_Click(object sender, EventArgs e)  
  3.         {  
  4.             //声明一个Bool类型的变量用来接收登录状态(是否登录成功)   
  5.             bool result = false;  
  6.   
  7.             //判断用户名跟密码是否为空   
  8.             if (txtUserName.Text == "")  
  9.             {  
  10.                 MessageBox.Show("用户名不能为空!");  
  11.                 txtUserName.Focus();  
  12.                 return;  
  13.             }  
  14.   
  15.             if (txtPwd.Text == "")  
  16.             {  
  17.                 MessageBox.Show("密码不能为空!");  
  18.                 txtPwd.Focus();  
  19.                 return;  
  20.             }  
  21.   
  22.             //声明一个用户对象   
  23.             User euser = new User();  
  24.             euser.UserName = txtUserName.Text.Trim();  
  25.             euser.Pwd = txtPwd.Text.Trim();  
  26.   
  27.             LoginBLL blogin = new LoginBLL();  
  28.             result = blogin.BLogin(euser);  
  29.   
  30.            //判断是否登录成功   
  31.             if (result == true)  
  32.             {  
  33.                 MessageBox.Show("登录成功!");  
  34.             }  
  35.             else  
  36.             {  
  37.                 MessageBox.Show("登录失败!");  
  38.             }  
  39.         }  
  40.   
  41.         //单击取消按钮   
  42.         private void btnCancel_Click(object sender, EventArgs e)  
  43.         {  
  44.             this.Close();  
  45.         }  
//单击登录按钮private void btnLogin_Click(object sender, EventArgs e){//声明一个Bool类型的变量用来接收登录状态(是否登录成功)bool result = false;//判断用户名跟密码是否为空if (txtUserName.Text == ""){MessageBox.Show("用户名不能为空!");txtUserName.Focus();return;}if (txtPwd.Text == ""){MessageBox.Show("密码不能为空!");txtPwd.Focus();return;}//声明一个用户对象User euser = new User();euser.UserName = txtUserName.Text.Trim();euser.Pwd = txtPwd.Text.Trim();LoginBLL blogin = new LoginBLL();result = blogin.BLogin(euser);//判断是否登录成功if (result == true){MessageBox.Show("登录成功!");}else{MessageBox.Show("登录失败!");}}//单击取消按钮private void btnCancel_Click(object sender, EventArgs e){this.Close();}

 

 

下面是BLL(业务逻辑)层的代码:

[csharp] view plain copy print ?
  1. public class LoginBLL  
  2.    {  
  3.   
  4.        /// <summary>   
  5.        /// 验证密码是否正确   
  6.        /// </summary>   
  7.        /// <param name="User"></param>   
  8.        /// <returns></returns>   
  9.        public bool BLogin(User User)  
  10.        {  
  11.            UserDAL duser = new UserDAL();  
  12.            User euser = new User();  
  13.            euser = duser.DLogin(User);  
  14.            if (euser.Pwd == User.Pwd)  
  15.            {  
  16.                return true;  
  17.            }  
  18.            else  
  19.            {  
  20.                return false;  
  21.            }  
  22.        }  
  23.    }  
 public class LoginBLL{/// <summary>/// 验证密码是否正确/// </summary>/// <param name="User"></param>/// <returns></returns>public bool BLogin(User User){UserDAL duser = new UserDAL();User euser = new User();euser = duser.DLogin(User);if (euser.Pwd == User.Pwd){return true;}else{return false;}}}



以下是DAL(数据访问)层的代码:

 

[csharp] view plain copy print ?
  1. public class UserDAL  
  2.    {  
  3.   
  4.        static string conString = "data source=RONALDINHO-PC;database=charge system;uid=sa;pwd=123456";  
  5.        SqlConnection cnn = new System.Data .SqlClient .SqlConnection (conString);  
  6.   
  7.        /// <summary>   
  8.        /// 根据输入的用户名取出用户密码   
  9.        /// </summary>   
  10.        /// <param name="user"></param>   
  11.        /// <returns></returns>   
  12.        public User  DLogin(User user)  
  13.        {  
  14.            string sqlString = "select * from UserInfo where UserName='" + user.UserName +"'"  ;  
  15.            User euser = new User();  
  16.            SqlCommand cmd =new SqlCommand(sqlString, cnn);  
  17.            cnn.Open();  
  18.            SqlDataReader read ;  
  19.            read = cmd.ExecuteReader();  
  20.            read.Read();  
  21.            euser .UserName  = read[0].ToString();  
  22.            euser.Pwd = read[1].ToString();  
  23.            return euser   ;  
  24.            
  25.        }  
  26.    }  
 public class UserDAL{static string conString = "data source=RONALDINHO-PC;database=charge system;uid=sa;pwd=123456";SqlConnection cnn = new System.Data .SqlClient .SqlConnection (conString);/// <summary>/// 根据输入的用户名取出用户密码/// </summary>/// <param name="user"></param>/// <returns></returns>public User  DLogin(User user){string sqlString = "select * from UserInfo where UserName='" + user.UserName +"'"  ;User euser = new User();SqlCommand cmd =new SqlCommand(sqlString, cnn);cnn.Open();SqlDataReader read ;read = cmd.ExecuteReader();read.Read();euser .UserName  = read[0].ToString();euser.Pwd = read[1].ToString();return euser   ;}}



其实三层理解起来很简单,就是把不同的责任划分到不同的层,以达到解耦的目的。分层的目的就是为了让程序变得高内聚、低耦合,使代码更加灵活、易扩展,让代码更具有易用性等等。说一千道一万也没什么作用,只有通过实践才能更深刻的体会三层的意义,所以希望和我一样的菜鸟们看完这篇博客就动手去做吧!

 

PS:此博客的题目纯属为了吸引人,我不敢说我写的这篇博客就是最简单明了的三层实例,只是把我的理解拿出来跟大家分享一下,所以高手看到后一笑而过就好了,千万别喷我...

 

转载于:.html

本文发布于:2024-02-04 22:12:59,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170717580560068.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23