asp.net中修改密码的代码.

如图,求大神解答!protectedvoidbtnSave_Click(objectsender,EventArgse){conn.Open();SqlCommandcm... 如图,求大神解答! protected void btnSave_Click(object sender, EventArgs e) { conn.Open(); SqlCommand cmd = new SqlCommand(); cmd.Connection = conn; cmd.CommandText = "select * from User where User_Account='" + Session["User_Account"].ToString() + "'and User_Pwd='" + txtPwd.Text.Trim() + "'"; SqlDataReader sdr = cmd.ExecuteReader(); try { if (sdr.Read()) { SqlCommand updatecmd = new SqlCommand("update User set User_Pwd='" + txtPwd2.Text.Trim() + "'where User_Account='" + Session["User_Account"].ToString() + "'", conn); int i = updatecmd.ExecuteNonQuery(); if (i == 1) { Response.Write("密码修改成功"); } else { Response.Write("密码修改失败'"); } } else { Response.Write("原密码错误"); } } catch (System.Exception ee) { Response.Write("<script language =javascript>alert('" + ee.Message.ToString() + "')</script>"); } finally { conn.Close(); sdr.Close(); }
SqlConnection conn = new SqlConnection("Data Source=LENOVO-PC\\MRWWK;Initial Catalog=Book;Persist Security Info=True;User ID=sa;Password=123456");
protected void btnSave_Click(object sender, EventArgs e)
{
conn.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "select * from User where User_Account='" + Session["User_Account"].ToString() + "'and User_Pwd='" + txtPwd.Text.Trim() + "'";
SqlDataReader sdr = cmd.ExecuteReader();
try
{
if (sdr.Read())
{
SqlCommand updatecmd = new SqlCommand("update User set User_Pwd='" + txtPwd2.Text.Trim() + "'where User_Account='" + Session["User_Account"].ToString() + "'", conn);
int i = updatecmd.ExecuteNonQuery();
if (i == 1)
{
Response.Write("密码修改成功");
}
else
{
Response.Write("密码修改失败'");
}
}
展开
 我来答
天堂画家
2017-12-25 · 超过50用户采纳过TA的回答
知道小有建树答主
回答量:65
采纳率:91%
帮助的人:46.3万
展开全部

检查一下cmd.CommandText=这一句,特别是Session["User_Account"].ToString()这个,调试看一看到底有没有值。

小技巧:“未将对象引用设置到对象的实例”多数原因就是因为对象内部没有值,比如null之类的造成的。

更多追问追答
追问
怎么调试啊。。。数据库里有值啊
追答
用断点调试吧,给cmd.CommandText下面那句话打一个断点(VS2013里选中这行按F9也行),然后再运行程序,然后程序就会运行到断点处,此时把鼠标放到cmd.CommandText上,看显示的sql语句是什么样子,会不会原因就是sql语句拼接的不完整。
数据库虽然有值,但那只是数据库的值。这里要强调的是sql语句到底对不对。比如Session["User_Account"]根本没获取到Session所以是空之类的。如果sql语句拼接都不完整,那么肯定无法从数据库查询到数据。报错信息里明确给出了出错的语句位置以及出错原因,因此问题肯定就是sql语句这里。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式