c#——三层登陆
来源:互联网 发布:数据存储技术 编辑:程序博客网 时间:2024/06/05 02:20
接下来通过一个实例具体的看怎么用三层实现用户登陆界面。
三、BLL层代码
登陆:
一、Model实体(LoginModel):
namespace LoginModel{ //添加类:UserInfo Model实体作用:封装数据,使数据在三层中传输 ,更倾向于业务逻辑层 public class UserInfo { //定义用户属性 public int ID { get; set; } public string UserName { get; set; } public string Password { get; set; } }}二、UI层的设计:
首先简单的界面相信大家都会:
接下来是代码:
namespace LoginUI{ public partial class frmLogin : Form { public frmLogin() { InitializeComponent(); } private void btnLogin_Click(object sender, EventArgs e) { //UI层将用户输入数据传递给BLL层 string userName = txtUserName.Text.Trim(); string password = txtPassword.Text; LoginBLL.LoginManager mgr = new LoginBLL.LoginManager(); LoginModel.UserInfo user = mgr.UserLogin(userName, password); //将UI层返回业务层传递的数据给用户 MessageBox.Show("登陆用户:" + user.UserName); } }}
三、BLL层代码
namespace LoginBLL{ public class LoginManager { public LoginModel.UserInfo UserLogin(string userName, string password) { LoginDAL.UserDAO uDao = new LoginDAL.UserDAO();//实例化DAL层 LoginModel.UserInfo user = uDao.SelectUser(userName, password); //不需访问数据源直接执行业务逻辑 if (user != null) { return user; } else { throw new Exception("登陆失败"); } } }}四、DAL层 代码
public class UserDAO { public LoginModel.UserInfo SelectUser(string userName, string Password) { //建立数据库连接 string ConnString = @"Server=192.168.24.154;DataBase=机房收费系统人员记录; User ID=sa; Password=123"; using (SqlConnection conn = new SqlConnection(ConnString)) { //执行SQL语句进行查询 SqlCommand cmd = conn.CreateCommand(); cmd.CommandText = @"SELECT ID,UserName,Password FROM UserInfo WHERE UserName=@UserName AND Password=@Password"; //输出查询结果 cmd.CommandType = CommandType.Text; //添加两个参数 cmd.Parameters.Add(new SqlParameter(@"UserName", userName)); cmd.Parameters.Add(new SqlParameter(@"Password", Password)); conn.Open(); SqlDataReader reader = cmd.ExecuteReader(); LoginModel.UserInfo user = null; //读取具体的数据 while (reader.Read()) { if (user == null) { user = new LoginModel.UserInfo(); } //读取查询到的数据 user.ID = reader.GetInt32(0); user.UserName = reader.GetString(1); user.Password = reader.GetString(2); } return user; } } }}
登陆:
结果显示:
阅读全文
0 0
- c#——三层登陆
- 【浅谈三层】——三层登陆
- 机房登陆——三层实践
- 剖析三层——登陆实例
- 三层总结(实践篇)——三层登陆VB.BET版
- C#-—登陆界面
- java web笔记——软件三层结构&MVC模式实现注册登陆案例
- 三层架构登陆
- .NET三层登陆实例
- 三层架构登陆实例
- 三层登陆实例
- .NET三层登陆
- 【三层】简单登陆
- 三层登陆实例
- 三层学习 之 登陆
- 【三层架构】登陆实例
- VB.NET三层登陆
- 【浅谈三层】——何为三层?
- 11. Container With Most Water题解
- Linux网络端口
- 查验身份证
- JAVA 8函数式编程(一):高阶函数
- 写测试类时没有@Test注解
- c#——三层登陆
- 一个整型数组里除了两个数字之外,其他的数字都出现了两次
- 50个必备的实用jQuery代码段+ 可以直接拿来用的15个jQuery代码片段
- LintCode(两数组的交)
- POJ 2154 Color Polya定理+欧拉函数优化
- c语言
- 扫描二维码+生成二维码
- NAT技术与代理服务器调研
- linux下桥接模式设置静态IP实现上网