有史以来最简单的三层实例(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

相关文章

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

C#中DrawCurve的用法小结

《C#中DrawCurve的用法小结》本文主要介绍了C#中DrawCurve的用法小结,通常用于绘制一条平滑的曲线通过一系列给定的点,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 如何使用 DrawCurve 方法(不带弯曲程度)2. 如何使用 DrawCurve 方法(带弯曲程度)3.使用Dr

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要