三层架构下实现用户登陆C#
2015-12-31 09:43
816 查看
上篇文章讲到三层。接下来就通过一个实例详细的看怎么用三层实现用户登陆界面。
一、Model实体(LoginModel):
首先简单的界面相信大家都会:
接下来是代码:
三、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; } } } }
登陆:
结果显示:
相关文章推荐
- 学网站设计有感三
- 架构师于小波:魅族实时消息推送架构
- 博客网站
- 猿题库 iOS 客户端架构设计-唐巧
- 杂志类网站参考
- cpu有哪些架构
- mysql高可用之MHA原理
- 艺龙十万级服务器监控系统开发的架构和心得
- android产品架构实践
- 微服务架构:服务间通讯机制
- 单体式应用向微服务架构迁移实践经验
- 【开源】.net 分布式架构之分布式缓存中间件
- mycncart使用教程 - 如何修改网站后台用户名密码
- USB设备架构
- 猿题库 iOS 客户端架构设计
- 架构设计:系统间通信(18)——服务治理与Dubbo 下篇(继续分析)
- 【精品资源】mobile微商城、webAPP手机网站、基于HTML5+CSS3移动端web开发!!!
- 技术架构选型
- 三层架构
- 浅谈三层架构与MVC模式的区别