C#三层架构实现用户注册模块

学习笔记。

《一都编程》的学习笔记
https://baijiahao.baidu.com/s?id=1657402566840735471&wfr=spider&for=pc

一、概述

  开发程序可以使用多种方法实现,但是程序开发的好坏,则要使用一种规范来约束,三层架构就是一种开发规范。

  这里使用.NET Web应用程序+C#+SQL Server搭建的经典.NET三层架构来实现用户注册功能。

  主要是通过用户注册功能来训练如何使用经典.NET三层架构完成Web应用程序的开发。

二、创建数据库表结构

  打开SQL Server的SSMS管理工具,添加一个名称为MyTest的数据库,并在此数据库中添加一个名称为UserInfo的表结构,如下图所示:

  表名为UserInfo,Id为主键,自增1。

三、创建项目

1、创建新项目

  选择ASP.NET Web应用程序(.NET Framework)

2、配置新项目

  输入项目名称My_LoginWeb;选择框架;

3、创建新的ASP.NET Web应用程序

  选择空;点击“创建”按钮。出现以下资源管理器界面

4、解决方案的信息

四、编写实体类Model

1、新建项目Model类库

  在解决方案上右击添加 ,选“新建项目”。选择类库(.NET Framework)。名称取名“Model”

2、建立UserInfo类

  把class1.cs改名为UserInfo.cs,如下图。

3、封装实体类

  现在根据UserInfo表中的字段来封装实体类,C#代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Model
{
        /// <summary>
        /// 用户信息实体
        /// </summary>
        public class UserInfo
        {
            /// <summary>
            /// 主键,学生编号
            /// </summary>
            public int Id { get; set; }
            /// <summary>
            /// 用户名
            /// </summary>
            public string UserName { get; set; }
            /// <summary>
            /// 密码
            /// </summary>
            public string Pwd { get; set; }
            /// <summary>
            /// 创建时间
            /// </summary>
            public DateTime CreateTime { get; set; }
        }
 }

这样就建立了实体类与数据库表之间的映射关系。

五、建立用户界面

1、新建Web窗体Register.aspx

  用户注册界面是供用户使用的,需要在UI层创建。在My_LoginWeb右击新建项;创建一个名称为“Register.aspx”的Web窗体,如下图所示:

2、添加布局页面

  在Register.aspx上右击“查看设计器”,布局页面,如下图:

3、添加代码

  编写“注册”按钮的事件C#代码,如下:

        /// <summary>
        /// 注册
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnRegister_Click(object sender, EventArgs e)
        {
            //接收值
            string userName = txtUserName.Text;
            string pwd = txtPwd.Text;
            if (userName != "" && pwd != "")
            {
                //实例化Model对象
                Model.UserInfo u = new Model.UserInfo();
                u.UserName = userName;
                u.Pwd = pwd;
                u.CreateTime = DateTime.Now;
                //添加到数据库操作,但在三层中,UI层只能调用BLL层,所以还要在BLL层中编写代码
                //调用BLL层中的方法
            }
        }

六、编写DAL层代码

1、引用DBHelper类库

  将已经封装的DBHelper帮助类库放在三层架构中的DAL项目中。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Web;
using System.Data.SqlClient;
using System.Data;

namespace DAL
{
    public class DBHelper
    {
        //创建连接对象
        SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=MyTest;Integrated Security=True");
        /// <summary>
        /// 执行sql语句返回受影响的行数
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public int ExcuteNonquery(string sql)
        {
            conn.Open();
            SqlCommand command = new SqlCommand(sql, conn);
            int count = command.ExecuteNonQuery();
            conn.Close();
            return count;
        }
        /// <summary>
        /// 返回首行首列数据
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public object ExcuteScalar(string sql)
        {
            conn.Open();
            SqlCommand command = new SqlCommand(sql, conn);
            object d = command.ExecuteScalar();
            conn.Close();
            return d;
        }
        /// <summary>
        /// 返回SqlDataReader对象
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public SqlDataReader DataReader(string sql)
        {
            conn.Open();
            SqlCommand command = new SqlCommand(sql, conn);
            SqlDataReader sdr = command.ExecuteReader(CommandBehavior.CloseConnection);
            return sdr;
        }
        /// <summary>
        /// 返回DataTable对象
        /// </summary>
        /// <param name="sql"></param>
        /// <returns></returns>
        public DataTable DataTable(string sql)
        {
            //创建适配器对象
            SqlDataAdapter adapter = new SqlDataAdapter(sql, conn);
            //创建数据集
            DataSet ds = new DataSet();
            //填充数据集
            adapter.Fill(ds);
            //返回datatable
            return ds.Tables[0];
        }
    }
}

2、创建DB类

  首先需要在DAL项目中添加一个所有与UserInfo表相关操作的C#类,在该类中封装操作数据库的方法,如:添加数据、修改数据、删除数据、查询数据等。
  在DAL中添加一个UserInfoDB类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Model;

namespace DAL
    {
        /// <summary>
        /// UserInfo数据库表相关操作
        /// </summary>
        public class UserInfoDB
        {
            //实例化DBHelper类
            DBHelper db = new DBHelper();
            /// <summary>
            /// 注册用户
            /// </summary>
            /// <param name="userInfo"></param>
            /// <returns></returns>
            public int UserRegister(Model.UserInfo userInfo)
            {
                //SQL语句
                string sql = string.Format("insert into UserInfo(UserName,Pwd,CreateTime) values('{0}','{1}','{2}')", userInfo.UserName, userInfo.Pwd, userInfo.CreateTime);
                int rows = -1;
                try//加入异常处理
                {
                    //开始执行向数据库插入数据操作
                    rows = db.ExcuteNonquery(sql);
                }
                catch (Exception ex)
                {
                    rows = -2;
                }
                return rows;
            }
        }
    }

在UserRegister()方法中,所传递的参数就是Model项目中的UserInfo实体对象。其中会带有一些值过来。这些值是从BLL层传过来的。

七、编写BLL层代码

  在BLL项目中添加一个名称为“UserInfoBLL”的类。然后添加对DAL和Model的引用。
  我们知道BLL主要处理一些业务逻辑,如果没有业务逻辑代码,直接调用DAL中相应的数据库操作即可,如下BLL层代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using DAL;
using Model;
namespace BLL
{
    /// <summary>
    /// 用户业务逻辑层
    /// </summary>
    public class UserInfoBLL
    {
        //实例化DAL类
        DAL.UserInfoDB userDB = new UserInfoDB();
        /// <summary>
        /// 注册用户
        /// </summary>
        /// <param name="userInfo"></param>
        /// <returns></returns>
        public int UserRegister(Model.UserInfo userInfo)
        {
            //在这里可以编写一些复杂的业务逻辑
            //将密码转换为小写
            string pwd = userInfo.Pwd.ToLower();
            //重新赋值,覆盖原来的值
            userInfo.Pwd = pwd;
            //调用DAL层的数据库访问代码
            int rows = userDB.UserRegister(userInfo);
            return rows;
        }
    }
}

八、UI层调用BLL层

再返回到注册页面aspx.cs文件中,补足调用BLL中的用户注册代码了:

                //调用BLL层中的方法
                /// <summary>
                /// 注册
                /// </summary>
                /// <param name="sender"></param>
                /// <param name="e"></param>
                BLL.UserInfoBLL uBLL = new BLL.UserInfoBLL();
                int rows = uBLL.UserRegister(u);
                        if (rows >= 1)
                        {
                            Response.Write("<script>alert('注册成功')</script>");
                        }       

九、运行结果

现在输入一个用户名和密码

点击注册,成功!

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个使用 ASP.NET 三层架构实现登录注册的示例代码: 首先,我们需要定义一个数据访问层(DAL),用于对数据库进行操作: ```csharp using System.Data; using System.Data.SqlClient; namespace DAL { public class UserDal { // 连接字符串 private readonly string connectionString = "Data Source=.;Initial Catalog=TestDB;Integrated Security=True"; // 根据用户名查询用户 public bool CheckUser(string username) { using (var conn = new SqlConnection(connectionString)) { var cmd = new SqlCommand("SELECT COUNT(*) FROM Users WHERE username=@username", conn); cmd.Parameters.AddWithValue("@username", username); conn.Open(); return ((int)cmd.ExecuteScalar() > 0); } } // 添加用户 public bool AddUser(string username, string password) { using (var conn = new SqlConnection(connectionString)) { var cmd = new SqlCommand("INSERT INTO Users(username,password) VALUES(@username,@password)", conn); cmd.Parameters.AddWithValue("@username", username); cmd.Parameters.AddWithValue("@password", password); conn.Open(); return (cmd.ExecuteNonQuery() > 0); } } // 根据用户名和密码查询用户 public bool Login(string username, string password) { using (var conn = new SqlConnection(connectionString)) { var cmd = new SqlCommand("SELECT COUNT(*) FROM Users WHERE username=@username AND password=@password", conn); cmd.Parameters.AddWithValue("@username", username); cmd.Parameters.AddWithValue("@password", password); conn.Open(); return ((int)cmd.ExecuteScalar() > 0); } } } } ``` 上述代码中,我们使用 ADO.NET 提供的 `SqlConnection` 和 `SqlCommand` 类对数据库进行操作,其中 `CheckUser` 方法用于检查用户名是否已存在,`AddUser` 方法用于添加新用户,`Login` 方法用于验证用户登录。 接下来,我们定义一个业务逻辑层(BLL),用于对数据访问层进行封装,提供更加友好的 API 接口: ```csharp using DAL; namespace BLL { public class UserBll { private readonly UserDal dal = new UserDal(); // 检查用户名是否已存在 public bool CheckUser(string username) { return dal.CheckUser(username); } // 注册新用户 public bool Register(string username, string password) { if (CheckUser(username)) { return false; // 用户名已存在 } return dal.AddUser(username, password); } // 用户登录 public bool Login(string username, string password) { return dal.Login(username, password); } } } ``` 在业务逻辑层中,我们调用数据访问层提供的方法进行操作,同时可以对返回结果进行处理,提供更加友好的 API 接口。 最后,我们定义一个 ASP.NET 页面,实现用户登录和注册的功能: ```csharp using BLL; namespace WebApplication1 { public partial class Login : System.Web.UI.Page { private readonly UserBll bll = new UserBll(); protected void Page_Load(object sender, EventArgs e) { } // 注册按钮点击事件 protected void btnRegister_Click(object sender, EventArgs e) { string username = txtUsername.Text.Trim(); string password = txtPassword.Text.Trim(); if (string.IsNullOrEmpty(username) || string.IsNullOrEmpty(password)) { lblMsg.Text = "用户名和密码不能为空!"; return; } if (bll.Register(username, password)) { lblMsg.Text = "注册成功,请登录!"; } else { lblMsg.Text = "用户名已存在,请重新输入!"; } } // 登录按钮点击事件 protected void btnLogin_Click(object sender, EventArgs e) { string username = txtUsername.Text.Trim(); string password = txtPassword.Text.Trim(); if (string.IsNullOrEmpty(username) || string.IsNullOrEmpty(password)) { lblMsg.Text = "用户名和密码不能为空!"; return; } if (bll.Login(username, password)) { lblMsg.Text = "登录成功!"; } else { lblMsg.Text = "用户名或密码错误,请重新输入!"; } } } } ``` 在 ASP.NET 页面中,我们调用业务逻辑层提供的方法进行操作,同时通过 `Page_Load` 方法初始化页面。需要注意的是,为了防止 SQL 注入攻击,我们应该对用户输入进行过滤和验证。此外,我们还需要将数据库连接字符串存储在配置文件中,以便在不同环境下进行配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值