asp.net登录界面找回密码后不能重置密码

zhinian9595 2019-04-19 08:53:13
小白遇到问题了,数据连接成功的,但是点击确定键后不能重置密码,到底是哪里的问题啊!代码和图片如下所示:







using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.SqlClient;
using System.Web.Security;


namespace WebApplication2
{
public partial class 找回密码 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
if (Request.QueryString["username"] == null)
{
Response.Redirect("登录.aspx");
}
}
lblName.Text = Request.QueryString["username"];
string connString = System.Configuration.ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
//声明Conn为一个SQL Server连接对象
SqlConnection Conn = new SqlConnection(connString);
Conn.Open(); //打开连接
string SelectSql = "select * from 用户表 where 用户名='" + lblName.Text + "'";
SqlDataAdapter da = new SqlDataAdapter(); //创建DataAdapter对象
da.SelectCommand = new SqlCommand(SelectSql, Conn);
DataSet ds = new DataSet(); //创建一个空DataSet对象
//将DataAdapter执行SQL语句返回的结果填充到DataSet对象
da.Fill(ds);
Conn.Close();
if (ds.Tables[0].Rows.Count == 0)
{
Response.Write("<script language=javascript>alert('用户名不存在!');</script>");
return;
}
DataRow MyRow = ds.Tables[0].Rows[0];
lblQuestion.Text = MyRow[3].ToString().Trim();
}

protected void lbtnOK_Click(object sender, EventArgs e)
{
string connString = System.Configuration.ConfigurationManager.ConnectionStrings["ConnStr"].ConnectionString;
//声明Conn为一个SQL Server连接对象
SqlConnection Conn = new SqlConnection(connString);
Conn.Open(); //打开连接
string SelectSql = "select * from 用户表 where 用户名='" + lblName.Text + "'";
SqlDataAdapter da = new SqlDataAdapter(); //创建DataAdapter对象
da.SelectCommand = new SqlCommand(SelectSql, Conn);
DataSet ds = new DataSet(); //创建一个空DataSet对象
//将DataAdapter执行SQL语句返回的结果填充到DataSet对象
da.Fill(ds);
string SecAnswer = FormsAuthentication.HashPasswordForStoringInConfigFile(textAnswer.Text, "MD5");
DataRow MyRow = ds.Tables[0].Rows[0];
if (SecAnswer == MyRow[4].ToString().Trim())
{
SqlCommandBuilder scb = new SqlCommandBuilder(da);
Random r = new Random();
string NewPwd = r.Next(100000, 999999).ToString();
Response.Write("<script language=javascript>alert('你的新密码是:" + NewPwd + ",请及时更改!');</script>");
NewPwd = FormsAuthentication.HashPasswordForStoringInConfigFile(NewPwd, "MD5");
MyRow["密码"] = NewPwd;
da.Update(ds); //将DataSet中数据变化提交到数据库(更新数据库)
Conn.Close();
}
else
{
Response.Write("<script language=javascript>alert('安全问题答案错!');</script>");
}
}

protected void lbtnBack_Click(object sender, EventArgs e)
{
Response.Redirect("登录.aspx");
}
}
}
...全文
400 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
更新即修改。。。
大鱼> 2019-04-25
  • 打赏
  • 举报
回复
都是这样一步一步过来的
醉雨烟岚 2019-04-25
  • 打赏
  • 举报
回复
我正 研究呢 谢谢大家分享
  • 打赏
  • 举报
回复
引用 2 楼 zhinian9595 的回复:
[quote=引用 1 楼 好奇都是要学的 的回复:] 没用过da.Update , 直接 string SelectSql = "update 表 set 密码=“新密码” where 用户名='" + lblName.Text + "'"; SqlDataAdapter da = new SqlDataAdapter(); //创建DataAdapter对象 da.SelectCommand = new SqlCommand(SelectSql, Conn);
这样不是在更新数据库,是修改了啊[/quote] 有区别?
zhinian9595 2019-04-19
  • 打赏
  • 举报
回复
引用 1 楼 好奇都是要学的 的回复:
没用过da.Update , 直接 string SelectSql = "update 表 set 密码=“新密码” where 用户名='" + lblName.Text + "'"; SqlDataAdapter da = new SqlDataAdapter(); //创建DataAdapter对象 da.SelectCommand = new SqlCommand(SelectSql, Conn);
这样不是在更新数据库,是修改了啊
  • 打赏
  • 举报
回复
没用过da.Update , 直接 string SelectSql = "update 表 set 密码=“新密码” where 用户名='" + lblName.Text + "'"; SqlDataAdapter da = new SqlDataAdapter(); //创建DataAdapter对象 da.SelectCommand = new SqlCommand(SelectSql, Conn);
注意:sqlserver2005,sql2008,sql2012以上版本都可以运行的哦 系统特点: 1、多种题型,支持简答题,并且简单题的评阅需要管理手工评阅,其他提醒由计算机自动评阅 2、加入了权限管理,系统分为三种用户,管理员、教师和学生,管理员可以设定教师有哪些权限 3、“在用户管理”这一模块中,还增加了一个“重置密码”的功能,如果用户忘记密码了,管理员则可以把用户的密码重置 4、系统的登陆只用了一个界面,不用单选按钮就可以实现三种用户的智能登陆,会自动根据身份跳转到相应的页面 5、另外还用了Cookie实现了记住用户名,方便用户的输入 6、学生登陆成功后,可以修改个人密码,查看考试记录,也可以选择考试 7、界面美观方面,不同的权限显示不同的界面内容 系统后台功能: 个人信息管理 修改密码 部门信息管理 部门管理 用户信息管理 用户管理 权限设置 试卷制定维护 试卷制定(随机出题、人工出题) 试卷维护 用户试卷管理 试卷评阅 用户成绩 试题类别管理 单选题维护 多选题维护 判断题维护 填空题维护 问答题 Database下为Sql数据库文件,在sqlserver2000的企业管理器中附加即可,数据库的连接用户名:sa 密码:198517 如果你的数据库不一样,只需要到web.config文件中修改即可 管理员登陆帐号:admin 密码:admin 教师用户登陆帐号:wangjianlin 密码:198517 测试学生帐号1: 200305030317 密码:123 测试学生帐号2: 200305030318 密码:123
系统特点: 1、多种题型,支持简答题,并且简单题的评阅需要管理手工评阅,其他提醒由计算机自动评阅 2、加入了权限管理,系统分为三种用户,管理员、教师和学生,管理员可以设定教师有哪些权限 3、“在用户管理”这一模块中,还增加了一个“重置密码”的功能,如果用户忘记密码了,管理员则可以把用户的密码重置 4、系统的登陆只用了一个界面,不用单选按钮就可以实现三种用户的智能登陆,会自动根据身份跳转到相应的页面 5、另外还用了Cookie实现了记住用户名,方便用户的输入 6、学生登陆成功后,可以修改个人密码,查看考试记录,也可以选择考试 7、界面美观方面,不同的权限显示不同的界面内容 系统后台功能: 个人信息管理 修改密码 部门信息管理 部门管理 用户信息管理 用户管理 权限设置 试卷制定维护 试卷制定(随机出题、人工出题) 试卷维护 用户试卷管理 试卷评阅 用户成绩 试题类别管理 单选题维护 多选题维护 判断题维护 填空题维护 问答题 Database下为Sql数据库文件,在sqlserver2000的企业管理器中附加即可,数据库的连接用户名:sa 密码:198517 如果你的数据库不一样,只需要到web.config文件中修改即可 管理员登陆帐号:admin 密码:admin 教师用户登陆帐号:wangjianlin 密码:198517 测试学生帐号1: 200305030317 密码:123 测试学生帐号2: 200305030318 密码:123
最新版本地址: http://download.csdn.net/source/823721 演示地址: http://netfocus.b13.cnwg.cn/ 核心功能介绍  论坛前台: 1. 用户注册、登陆、注销; 2. 版块导航:显示所有的版块分组和版块; 3. 帖子列表:显示当前版块下所有的帖子,可以区分置顶帖子、精华帖子、推荐帖子; 4. 帖子内容:显示帖子内容; 5. 帖子回复:显示帖子的回复列表; 6. 添加帖子:用户添加新帖; 7. 添加回复:用户添加回复; 8. 精华帖子列表:显示所有的精华帖子; 9. 推荐帖子列表:显示所有的推荐帖子; 10. 帖子管理:具有帖子管理权限的人对帖子进行管理; 11. 回复管理:具有帖子回复管理权限的人对帖子回复进行管理;  论坛后台: 1. 版块组管理:添加、删除、修改; 2. 版块管理:添加、删除、修改,添加或修改时通过下拉框选择版块组; 3. 版主管理:可以管理论坛中每个版块的版主,如添加、删除版主; 4. 用户管理:查看用户资料、删除用户、封锁用户、解锁用户、重置密码; 5. 角色管理:添加、删除、修改; 可以定义如下角色: 系统管理员、用户管理员、角色管理员、版块管理员、版主管理员、版主、Owner、注册用户、所有人;其中Owner指发帖人,回复人;另外系统管理员、注册用户、所有人是内置角色,不能修改或删除;下面分别对每种角色的含义进行说明: 1) 系统管理员:拥有论坛所有权限; 2) 用户管理员:拥有用户管理权限; 3) 角色管理员:拥有角色管理权限; 4) 版块管理员:拥有版块管理权限; 5) 版主管理员:拥有版主管理权限; 6) 版主:拥有所有论坛事务管理权限; 7) Owner:拥有对自己发表的帖子或回复的内容进行修改的权限;(此角色可以考虑禁用,出于数据真实性考虑,因为任何人都要对他或她所说的言行负责,不允许随便修改); 8) 注册用户:拥有一部分论坛事务,如看帖,发帖,回帖,管理和自己相关的一些帖子; 9) 所有人:这个角色只是一个映射角色,任何登陆网站的人都自动拥有此角色;此角色可以表示匿名用户;仅拥有此角色的人一般只能看帖,不能做其他任何事情。当然如果愿意,我们也可以给它分配更多的权限,如发帖,回帖。如果这样,那就意味着运行匿名用户发帖或回帖了。 6. 用户角色管理:对任意一个用户的所属角色进行管理(包括添加和删除用户所属角色); 7. 角色权限管理:分为两类进行管理; 系统管理权限:用户管理、角色管理、版块管理、版主管理; 论坛事务管理权限:浏览帖子、发表帖子、修改帖子内容,修改帖子类型(包括设置为置顶帖子、推荐帖子或精华帖子)、删除帖子、移动帖子(就是从一个版块移动到另外一个版块)、修改回复、删除回复; 因为权限分为两种,所以角色权限管理也可以采用两个界面实现。这两个界面的行就是所有角色,列就是当前权限类型下的所有权限点。 8. 头像设置:设置用户的头像; 9. 密码修改; 10. 我的帖子管理:有我发布的帖子,我回复的帖子; 有一点需要在说明一下,就是版主管理模块如何实现呢? 我觉得可以这样实现: 首先定位到某个版块,然后点击版主设置,然后在出来的页面中可以把所有有版主角色的用户显示出来,比如用CheckBox显示。然后如果你想让谁做当前版块的版主,就打勾。然后保存就行。这样一来,被打勾的用户就是该版块的版主了。同一用户可以同时为多个版块的版主; 另外,一个论坛可能还常常有星级评定,积分设置,界面管理,等等其他辅助功能。这些东西可以在日后慢慢补充。
论坛演示地址: http://netfocus.b13.cnwg.cn 论坛功能设计  论坛前台: 1. 用户注册、登陆、注销; 2. 版块导航:显示所有的版块分组和版块; 3. 帖子列表:显示当前版块下所有的帖子,可以区分置顶帖子、精华帖子、推荐帖子; 4. 帖子内容:显示帖子内容; 5. 帖子回复:显示帖子的回复列表; 6. 添加帖子:用户添加新帖; 7. 添加回复:用户添加回复; 8. 精华帖子列表:显示所有的精华帖子; 9. 推荐帖子列表:显示所有的推荐帖子; 10. 帖子管理:具有帖子管理权限的人对帖子进行管理; 11. 回复管理:具有帖子回复管理权限的人对帖子回复进行管理;  论坛后台: 1. 版块组管理:添加、删除、修改; 2. 版块管理:添加、删除、修改,添加或修改时通过下拉框选择版块组; 3. 版主管理:可以管理论坛中每个版块的版主,如添加、删除版主; 4. 用户管理:查看用户资料、删除用户、封锁用户、解锁用户、重置密码; 5. 角色管理:添加、删除、修改; 默认定义如下角色: 系统管理员、用户管理员、角色管理员、版块管理员、版主管理员、版主、所有者、注册用户、所有人;其中所有者指发帖人,回复人;另外系统管理员、注册用户、所有者、所有人是内置角色,不能修改或删除;下面分别对每种角色的含义进行说明: 1) 系统管理员:拥有论坛所有权限; 2) 用户管理员:拥有用户管理权限; 3) 角色管理员:拥有角色管理权限; 4) 版块管理员:拥有版块管理权限; 5) 版主管理员:拥有版主管理权限; 6) 版主:拥有所有论坛事务管理权限; 7) 所有者:拥有对自己发表的帖子或回复的内容进行修改的权限;(此角色可以考虑禁用,出于数据真实性考虑,因为任何人都要对他或她所说的言行负责,不允许随便修改); 8) 注册用户:拥有一部分论坛事务,如看帖,发帖,回帖,管理和自己相关的一些帖子; 9) 所有人:这个角色只是一个映射角色,任何登陆网站的人都自动拥有此角色;此角色可以表示匿名用户;仅拥有此角色的人一般只能看帖,不能做其他任何事情。当然如果愿意,我们也可以给它分配更多的权限,如发帖,回帖。如果这样,那就意味着运行匿名用户发帖或回帖了。 6. 用户角色管理:对任意一个用户的所属角色进行管理(包括添加和删除用户所属角色); 7. 角色权限管理:分为两类进行管理; 系统管理权限:用户管理、角色管理、版块管理、版主管理; 论坛事务管理权限:浏览帖子、发表帖子、编辑帖子、置顶帖子、设为推荐帖子、设为精华帖子、删除帖子、修改回复、删除回复; 因为权限分为两种,所以角色权限管理也可以采用两个界面实现。这两个界面的行就是所有角色,列就是当前权限类型下的所有权限点。 8. 头像设置:设置用户的头像; 9. 密码修改; 10. 我的帖子管理:有我发布的帖子,我回复的帖子; 另外,一个论坛可能还常常有星级评定,积分设置,界面管理,等等其他辅助功能。这些东西可以在日后慢慢补充。

17,740

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 .NET Framework
社区管理员
  • .NET Framework社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧