背景

  • 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了。

    网站介绍

  • 根据书上的例子做了一个比较粗糙的登录例子,里面的代码都是自己敲出来的,而且很少使用封装方法,就是为了让自己能更清楚的记住做的过程。
  • 这个网站包含注册、登录、修改密码三个功能。
  • 注册介绍

  • 新建一个Web窗体,即UserManagers.aspx。不粘贴前台代码了。然后编写注册方法,包括用户名当作主键,SqlDataReader方式读取数据库,SqlCommand参数添加数据等要点
  • protected void Button1_Click(object sender, EventArgs e)
    {
    if (txtName.Text == "" || txtPwd.Text == "" || txtConfirm.Text == "")
    {
    this.Page.RegisterStartupScript("ss", "<script>alert('用户名密码不能为空')</script>");
    return;
    } if (txtPwd.Text.Equals(txtConfirm.Text))
    {
    //查看当前用户是否存在
    SqlConnection sqlConn = new SqlConnection(ConfigurationManager.ConnectionStrings["connection"].ConnectionString);
    sqlConn.Open();
    string sql = "select * from tb_user where username = '" + txtName.Text.Trim() + "'";
    SqlCommand sqlCommand = new SqlCommand(sql, sqlConn);
    SqlDataReader sqlDataReader = sqlCommand.ExecuteReader();
    if (sqlDataReader.Read())
    {
    Page.RegisterStartupScript("", "<script>alert('用户名已存在!')</script>");
    return;
    }
    sqlDataReader.Close(); //新增用户
    string strInsert = "insert into tb_user(username, pwd, marks) values (@username,@pwd, @marks)";
    sqlCommand = new SqlCommand(strInsert, sqlConn);
    sqlCommand.Parameters.Add("@username", SqlDbType.VarChar);
    sqlCommand.Parameters["@username"].Value = txtName.Text; sqlCommand.Parameters.Add("@pwd", SqlDbType.VarChar, 20);
    sqlCommand.Parameters["@pwd"].Value = txtPwd.Text; sqlCommand.Parameters.Add("@marks", SqlDbType.VarChar, 1000);
    sqlCommand.Parameters["@marks"].Value = "zbq测试"; sqlCommand.ExecuteNonQuery();
    sqlConn.Close(); Page.RegisterStartupScript("", "<script>alert('注册成功!')</script>");
    Response.Redirect("Default.aspx?Name=" + txtName.Text + "");
    }
    }

    界面效果如下

    登录介绍

  • 首先添加登录窗口ManageLogin.aspx,然后写登录代码,包含验证码这一要点

  • protected void btnLogin_Click(object sender, EventArgs e)
    {
    if (string.IsNullOrEmpty(txtName.Text)|| string.IsNullOrEmpty(txtPwd.Text) || string.IsNullOrEmpty(txtValid.Text))
    {
    Page.RegisterStartupScript("", "<script>alert('信息填写不完全!')</script>");
    return;
    }
    if (!txtValid.Text.ToUpper().Equals(Session["ValidNums"]))
    {
    Page.RegisterStartupScript("", "<script>alert('验证码不正确!')</script>");
    return;
    } SqlConnection sql = new SqlConnection(ConfigurationManager.ConnectionStrings["connection"].ConnectionString);
    sql.Open(); string select = "select * from tb_user t where t.username = '" + txtName.Text.Trim() + "' and pwd = '" + txtPwd.Text.Trim() +
    "'"; SqlCommand command = new SqlCommand(select, sql); SqlDataReader dataReader = command.ExecuteReader(); if (dataReader.Read())
    {
    //成功就跳转
    Response.Redirect("Default.aspx?Name=" + txtName.Text + "");
    }
    else
    {
    Page.RegisterStartupScript("", "<script>alert('账户名或密码错误!')</script>");
    dataReader.Close();
    return;
    }
  • 登录效果如图
  •   

    修改密码介绍

  • 首先建立一个EditPwd.aspx窗体
  • <table class="table" border="1px" align="center">
    <tr>
    <td class="firstTd">用户名:</td>
    <td >
    <asp:DropDownList runat="server" ID="names" Width="200px" Height="20px" />
    </td>
    </tr>
    <tr>
    <td class="firstTd">原密码:</td>
    <td >
    <asp:TextBox runat="server" ID="txtOldPwd" TextMode="Password" />
    </td>
    </tr>
    <tr>
    <td class="firstTd">新密码:</td>
    <td >
    <asp:TextBox runat="server" ID="txtNewPwd" TextMode="Password"></asp:TextBox>
    </td>
    </tr>
    <tr>
    <td class="firstTd">&nbsp;</td>
    <td align="right">
    <span >
    <asp:Button runat="server" ID="btnSure" OnClick="btnSure_Click" Text="确认登录"/>
    <asp:Button runat="server" ID="btnCancle" OnClick="btnCancle_Click" Text="取消"/>
    </span>
    </td>
    </tr> </table>

    然后编写修改方法,包含SqlDataAdapter + DataSet关键点

    protected void Page_Load(object sender, EventArgs e)
    {
    //初始化数据
    if (!IsPostBack)
    {
    SqlConnection sql = new SqlConnection(ConfigurationManager.ConnectionStrings["connection"].ConnectionString);
    sql.Open();
    string select = "select * from tb_user";
    SqlDataAdapter sqlDataAdapter = new SqlDataAdapter(select, sql); DataSet dataSet = new DataSet();
    sqlDataAdapter.Fill(dataSet);
    sql.Close();
    if (dataSet.Tables[0].Rows.Count> 0)
    {
    for (int index = 0; index < dataSet.Tables[0].Rows.Count; index++)
    {
    names.Items.Add(dataSet.Tables[0].Rows[index][1].ToString()); }
    }
    }
    }
    protected void btnSure_Click(object sender, EventArgs e)
    { if (string.IsNullOrEmpty(txtNewPwd.Text) || string.IsNullOrEmpty(txtOldPwd.Text))
    {
    Page.RegisterStartupScript("", "<script>alert('密码不能为空或者不能不相等!')</script>");
    return;
    } SqlConnection sqlConnection = new SqlConnection("server=PC-20150424DMHQ;database=MyDatas;uid=sa;pwd=123456");
    string select = "select * from tb_user where username = '" +names.Text + "'";
    SqlCommand sqlCommand = new SqlCommand(select, sqlConnection);
    sqlConnection.Open();
    SqlDataReader sqlDataReader = sqlCommand.ExecuteReader();
    if (sqlDataReader.Read())
    {
    if (sqlDataReader["pwd"].ToString() != txtOldPwd.Text)
    {
    Page.RegisterStartupScript("", "<script>alert('密码输入错误!')</script>");
    return;
    }
    }
    else
    {
    Page.RegisterStartupScript("", "<script>alert('数据库连接错误!')</script>");
    return;
    }
    sqlConnection.Close();
    sqlDataReader.Close(); //修改密码
    sqlConnection.Open();
    string updatePwd = "update tb_user set pwd = '" + txtNewPwd.Text + "' where username = '" + names.Text + "'";
    sqlCommand = new SqlCommand(updatePwd, sqlConnection); sqlCommand.ExecuteNonQuery();
    sqlConnection.Close();
    Page.RegisterStartupScript("", "<script>alert('修改成功!')</script>");
    Page_Load(null, null);
    }

    修改密码界面效果

    ASP.NET菜鸟之路之登录系统的更多相关文章

    1. ASP.NET菜鸟之路之Application小例子

      背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. Session介绍 Application对象用 ...

    2. ASP.NET菜鸟之路之实现新闻列表增删改

      背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. 网站介绍 根据视频的例子修改的方法,其中数据不经 ...

    3. ASP.NET菜鸟之路之Seesion小例子

      背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. Session介绍 Session保存特定用户相 ...

    4. ASP.NET菜鸟之路之Request小例子

      背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. Request获取值 Request获取值有两种 ...

    5. ASP.NET菜鸟之路之Response小例子

      背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. Response.Write Redirect ...

    6. 教你开发asp.net的单点登录系统

      单点登录系统,简称SSO.以下是我花了几个小时写的一个简单实现.特把实现思路和大家分享. 背景:某项目使用ASP.NET MemberShip来做会员系统,需要同时登录多个系统.而项目的开发人员无法在 ...

    7. 菜鸟之路——Linux基础::计算机网络基础,Linux常用系统命令,Linux用户与组权限

      最近又重新安排了一下我的计划.准备跟着老男孩的教程继续学习,感觉这一套教程讲的很全面,很详细.比我上一套机器学习好的多了. 他的第一阶段是Python基础,第二阶段是高等数学基础,主要将机器学习和深度 ...

    8. ASP.net 实现禁止用户重复登录

      本文先为大家介绍如何利用缓存Cache方便地实现此功能. Cache与Session这二个状态对像的其中有一个不同之处,Cache是一个全局对象,作用的范围是整个应用程序,所有用户:而Session是 ...

    9. Easyui + asp.net MVC 系列教程 完成登录

      Easyui + asp.net MVC 系列教程 第09-17 节 完成登录 高清录制 前面八节 在这里 Easyui + asp.net mvc + sqlite 开发教程(录屏)适合入门 在接下 ...

    随机推荐

    1. 只要是从事IT,会些CSS,XHTML总归是有好处的

      上次是十多年前看了的,这次又系统看了下.. 这系统的HEAD FIRST,我很喜欢...收藏过三四本啦...

    2. 图论(KM算法,脑洞题):HNOI 2014 画框(frame)

      aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABPoAAANFCAIAAABtIwXVAAAgAElEQVR4nOydeVxTV/r/n9ertaJEC4

    3. arcgis安装问题SDK开始安装不了

      arcgis安装问题SDK开始安装不了,提示安装Desktop10,安装Desktop10又提示装dotnetfx3.5sp1,最后其实不用这样,可以先把军事扩展包,补丁,安装好,再安装sdk就没有问 ...

    4. Python 实时日志平台 Sentry

      原文地址:http://www.oschina.net/p/sentry Sentry 是一个实时的事件日志和聚合平台,基于 Django 构建. Sentry 可以帮助你将 Python 程序的所有 ...

    5. HDU2059(龟兔赛跑)

      龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

    6. poj 3608 旋转卡壳求不相交凸包最近距离;

      题目链接:http://poj.org/problem?id=3608 #include<cstdio> #include<cstring> #include<cmath ...

    7. 苹果教你六招:设计优秀的icon

      在iOS 7测试版发布后,网上开始出现大量关于iOS 7设计的资源.在WWDC期间,苹果曾为开发者举办了多场主题演讲,其中有一场是苹果UX布道师Mike Stern的精彩演讲-- 优秀iOS设计最佳实 ...

    8. 虚拟机linux配置nginx 为什么win7通过Ip访问不到

      第一步,你应该先检查网络win机ping linux机,通了进行下一步第二步,检查端口netstat -antl | grep 你开启的服务端口比如你开了http,那就是80端口或者你自定义的端口,我 ...

    9. WCF 项目应用连载[3] - 双向通信 实例管理与服务端监控

      WCF 项目应用连载[1] - 索引 - 轻量级的Log系统 - Lig Sample -序 第二节我们已经创建了Lig项目,并且能稳定工作了.现在我们来改进ILigAgent接口,实现WCF的双向通 ...

    10. Android图片框架---Glide

      Glide *** 使用* 一.添加依赖* compile 'com.github.bumptech.glide:glide:3.7.0'* compile 'com.android.support: ...