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

2023-12-02 23:30

本文主要是介绍有史以来最简单的三层实例(C#) ——转载自CSDN,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

 

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

 

简单的三层划分:

 

 

用户登录界面:

 

 

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

 

 

下面是UI层的代码:

 

[csharp] view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  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 ? 在CODE上查看代码片 派生到我的代码片
  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 ? 在CODE上查看代码片 派生到我的代码片
  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:此博客的题目纯属为了吸引人,我不敢说我写的这篇博客就是最简单明了的三层实例,只是把我的理解拿出来跟大家分享一下,所以高手看到后一笑而过就好了,千万别喷我...

 

转载于:https://www.cnblogs.com/tianshuilv/p/3894570.html

这篇关于有史以来最简单的三层实例(C#) ——转载自CSDN的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447240

相关文章

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C#如何去掉文件夹或文件名非法字符

《C#如何去掉文件夹或文件名非法字符》:本文主要介绍C#如何去掉文件夹或文件名非法字符的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#去掉文件夹或文件名非法字符net类库提供了非法字符的数组这里还有个小窍门总结C#去掉文件夹或文件名非法字符实现有输入字