c#三层架构登陆实例
很早之前,就听说过三层结构了。当时只知道 三层结构 是把 系统的 界面 跟 数据库操作等不相关的程序分别开来。原来这么简单的实现,确实传说中的 三层结构啊。
首先,先来看一下是哪三层。表示层(UI,User Interface),业务逻辑层(BLL BusinessLogicLayer),数据访问层(DAL Data Access Layer)。三层的划分是物理上的划分。
表示层(UI),这个最容易理解,就是用户看到的主界面。
数据访问层(DAL),也不难理解,主要是负责数据的增删改查。
业务逻辑层(BLL),算是表示层和数据访问层的桥梁吧。里面主要存放一些业务流程。也就是逻辑。主要作用就是从DAL中获取数据,然后显示到UI上。
举一个例子,三层结构可以用饭店的实例来理解。

UI 指的是服务员, BLL 是厨师, DAL 是采购员。
在顾客的眼里,只能看到服务员为他们服务。并不知道后台厨师和采购员 是如何做的。对于上述三种不同的角色来说,无论哪个环节出了问题,只需要更换一个员工就可以照常营业的。
三层架构的优势,还是职责分离,降低耦合。
接下来,看一个使用三层结构的登陆实例。首先,需要声明一下。这个实例中有很多 bug 需要优化。不过对于展示三层的主要思想足够了。仅仅是一个实例而已。
数据库表:

这是数据模块图:

细心的读者肯定会发现,除了 UI,BLL,DAL 这三个之外还有一个 Moudel 存在,这个 Moudel 不属于任何一层,只是为了更好地链接三层而存在的。这个类只存储,与以上三类共同使用的东西。起一个 协调的作用。 Moudel 类,也就是实体类。
下面是这几个层次的关系。

接下来需要看一下,他们分别是如何实现各自的分工的。
UserModel类:
namespace LoginModel
{
/// <summary>
/// 实体类,用于保存用户信息
/// </summary>
public class UserModel
{
public int Id { get; set; }
public string UserName { get; set; }
public string UserPwd { get; set; }
}
}
UI层:
private void btnLogin_Click(object sender, EventArgs e)
{
try
{
////取出用户界面的数据
string userName = txtUserName.Text.Trim();
string userPwd = txtUserPwd.Text;
UserBLL userBll = new UserBLL();//实例化一个业务逻辑层BLL
UserModel userModel = userBll.UserLogin(userName, userPwd);//使用用户界面数据,进行查找BLL数据
MessageBox.Show("登陆用户:" + userModel.UserName);
}
catch (Exception ex) //如果登陆有异常 则登陆失败
{
MessageBox.Show(ex.Message);
}
}
BLL层:
namespace LoginBLL
{
/// <summary>
/// //业务逻辑层
/// </summary>
public class UserBLL
{
public UserModel UserLogin(string userName, string userPwd)
{
UserDAL userDal = new UserDAL();//实例化一个数据访问层
UserModel user = userDal.SelectUser(userName, userPwd);////通过ui中填写的内容 返回来相应的数据
if (user != null)
{
return user;//如果数据库中有数据,则返回一个实体类
}
else
{
throw new Exception("登陆失败");
}
}
}
}
DAL层:
UserDAL类:
namespace LoginDAL
{
public class UserDAL
{
////根据 ui 选择返回一个user
public UserModel SelectUser(string userName, string userPwd)
{
using (SqlConnection conn = new SqlConnection(DbUtil.connString))
{
//创建一个命令对象,并添加命令
SqlCommand cmd = conn.CreateCommand();
cmd.CommandText = @"select Id,UserName,UserPwd from T_UserInfo where UserName=@UserName and UserPwd=@UserPwd";
cmd.CommandType = CommandType.Text;
cmd.Parameters.AddWithValue("@UserName",userName);
cmd.Parameters.AddWithValue("@UserPwd", userPwd);
conn.Open();//打开数据链接
SqlDataReader reader = cmd.ExecuteReader();
UserModel user = null; //用于保存读取的数据
while (reader.Read()) //开始读取数据
{
if (user == null) //如果没有,则重新生成一个
{
user = new UserModel();
}
user.Id = reader.GetInt32();
user.UserName = reader.GetString();
user.UserPwd = reader.GetString();
}
return user;
}
}
}
}
DbUtil类:
namespace LoginDAL
{
/// <summary>
/// //数据访问层,用于保存 链接服务器的sql语句
/// </summary>
class DbUtil
{
public static string connString = @"Server=xxx;Database=xx;User ID=sa; Password=123";
}
}
c#三层架构登陆实例的更多相关文章
- [转]C#三层架构登陆实例
很早之前,就听说过三层结构了.当时只知道 三层结构 是把 系统的 界面 跟 数据库操作等不相关的程序分别开来.原来这么简单的实现,确实传说中的 三层结构啊. 首先,先来看一下是哪三层.表示层(UI, ...
- 31、三层架构、AJAX+FormsAuthentication实现登陆
三层架构 前段时间公司要求修改一个网站,打开后我疯了,一层没有都是调用的DB接口,遍地的SQL语句,非常杂乱. 什么是三层架构? 三层架构是将整个项目划分为三个层次:表现层.业务逻辑层.数据访问层.目 ...
- JavaWeb学习之三层架构实例(三)
引言 通过上一篇博客JavaWeb学习之三层架构实例(二)我们基本上已经实现了对学生信息列表的增删改查操作(UI除外),但是不难看出,代码冗余度太高了,尤其是StudentDao这个类,其中的增删改查 ...
- JavaWeb学习之三层架构实例(二)
引言 这个实例是上一个实例JavaWeb学习 三层架构实例(一)的加强版,实现的是在前端对数据库中student表的 增.删.改.查 操作.关于三层组成云云,这里就不再叙述. 实例 效果图 先来看一下 ...
- C#三层架构实例
对于三层的概念查也查了,看也看了,下面是我找的一个关于三层的简单实例,真正看一下它是如何具体实现的. 我们先来一起看看 实体类-Model 实质:实体类就是在完成数据库与实体类对应的功能,一个类是一张 ...
- 三层架构(MVC)实现简单登陆注册验证(含验证码)
前言在我的上一篇微博里我已经提出了登陆的方法,当时我采取的是纯servlet方式,因为当时刚接触到servlet,正好网上没有这方面的全面讲解,所以我就发飙了.不过在现实生产中我们大多采用的三层架构. ...
- java:Session(概述,三层架构实例(实现接口封装JDBC),Session实现简单购物车实例)
1.Session概述: Session:在计算机中,尤其是在网络应用中,称为“会话控制”.Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 Web 页之间跳转时,存 ...
- C# 使用三层架构实例演示-winForm 窗体登录功能
---------------------------------------------------------------------------------------------------华 ...
- 新闻公布系统 (Asp.net 三层架构 )
2012年度课程设计---新闻公布系统(小结) ...
随机推荐
- Junit基础整理
项目引进Junit包 对待测试类新建testcase testcase类分为:@RunWith() -----@RunWith(suite.class)测试套件类打包测试 -----@RunWith( ...
- 题目1373:整数中1出现的次数(从1到n整数中1出现的次数)
题目1373:整数中1出现的次数(从1到n整数中1出现的次数) 题目描述: 亲们!!我们的外国友人YZ这几天总是睡不好,初中奥数里有一个题目一直困扰着他,特此他向JOBDU发来求助信,希望亲们能帮帮他 ...
- [开源类库/项目] android保存崩溃时的错误信息log至本地【源码+jar包+使用说...
不知大家是否经常遇到这种情况:自己的项目有时会在没有连接到电脑时发生崩溃,好不容易发现的bug结果连接到电脑时又复现不出来了:又或者自己写的一个功能在开机启动时产生小bug导致崩溃,而刚启动的机器想让 ...
- HDU 4939 Stupid Tower Defense(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4939 解题报告:一条长度为n的线路,路上的每个单元格可以部署三种塔来给走在这条路上的敌人造成伤害,第一 ...
- 《C和指针(Pointer on c)》 学习笔记(转自:http://dsqiu.iteye.com/blog/1687944)
首先本文是对参考中三个连接的博客进行的整理,非常感谢三位博主的努力,每次都感叹网友的力量实在太强大了…… 第一章 快速上手 1. 在C语言中用/*和*/来注释掉这段代码,这个实际上并不是十分的安全, ...
- 多通道(Multichannel)单通道(singlechannel)图像概念梳理
在做机器视觉时,常常要将一个多通道图像分离成几个单通道图像或者将几个单通道图像合成一个多通道图像,以方便图像处理,但是.写这篇博客,是为加深对这两个概念的理解,下面会给出部分OpenCV对单通道与多通 ...
- phpDocumentor 注释语法详解
PHPDocumentor是强大的代码注释生成器,本文对各个参数进行了简单地的总结: @abstract-------------使用@abstract标记来声明一个方法,类变量或类必须重新定义子类中 ...
- Python自动化之线程进阶篇(二)
queue队列 class queue.Queue(maxsize=0) #先入先出 class queue.LifoQueue(maxsize=0) #后入先出 class queue.Priori ...
- tornado 非阻塞方法
http://sebastiandahlgren.se/2014/06/27/running-a-method-as-a-background-thread-in-python/
- centos 6.5 下用apache部署web 应用
1. 修改/etc/httpd/conf/httpd.conf文件,添加一个virtualhost段,具体略.注意在段内配置NaveServer. 此文件全局也要配置一个NameServer(原因有待 ...