a.SelectCommand.Parameters["@username"].Value = username;处提示未将对象引用设置到对象的实例。。。。。求

dylanliu9301 2012-06-03 04:25:54
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Data;
using System.Web.Configuration;

namespace SkySharp
{
public partial class WebLogonForm : System.Web.UI.Page
{
string constr = "Data Source=admin-pc;Initial Catalog=skyShark;Integrated Security=true";

protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
using (SqlConnection con = new SqlConnection(constr))
{
DataSet dataSet1 = new DataSet();
string username, password;
int datarows = 0;
try
{
SqlCommand cmd = new SqlCommand("select * from dtUsers" + "where Username=@username and Password=@password", con);
username = txtUserName.Text.Trim();
cmd.Parameters.Add(new SqlParameter("@username", SqlDbType.NVarChar, 15));
username = txtUserName.Text.Trim();
cmd.Parameters.Add("@password", SqlDbType.NVarChar, 15);
password =txtPassword.Text.Trim();
con.Open();
SqlDataAdapter a = new SqlDataAdapter();
a.SelectCommand.Parameters["@username"].Value = username;
a.SelectCommand = cmd;

datarows = a.Fill(dataSet1, "dtUsers");
if (datarows==0)
lblMessage.Text = "Incorrect user name";
else
{
if (dataSet1.Tables["dtUsers"].Rows[0][1].ToString().Trim() == password)
{
lblMessage.Text = "good";
}
else
lblMessage.Text = "Incorrect password";
}
}
catch (SqlException) { }
finally
{
con.Close();
}
}

}
}
}
...全文
212 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
licai1210 2012-06-03
  • 打赏
  • 举报
回复
 protected void Button1_Click(object sender, EventArgs e)
{
using (SqlConnection con = new SqlConnection(constr))
{
DataSet dataSet1 = new DataSet();
string username, password;
int datarows = 0;
try
{
SqlCommand cmd = new SqlCommand("select * from dtUsers" + "where Username=@username and Password=@password", con);
username = txtUserName.Text.Trim();
cmd.Parameters.Add(new SqlParameter("@username", SqlDbType.NVarChar, 15));
username = txtUserName.Text.Trim();
cmd.Parameters.Add("@password", SqlDbType.NVarChar, 15);
password =txtPassword.Text.Trim();
con.Open();
SqlDataAdapter a = new SqlDataAdapter();
//次序换下就正确了
a.SelectCommand = cmd;

a.SelectCommand.Parameters["@username"].Value = username;


datarows = a.Fill(dataSet1, "dtUsers");
if (datarows==0)
lblMessage.Text = "Incorrect user name";
else
{
if (dataSet1.Tables["dtUsers"].Rows[0][1].ToString().Trim() == password)
{
lblMessage.Text = "good";
}
else
lblMessage.Text = "Incorrect password";
}
}
catch (SqlException) { }
finally
{
con.Close();
}
}

}
}
}


licai1210 2012-06-03
  • 打赏
  • 举报
回复
a.SelectCommand.Parameters["@username"].Value = username;
a.SelectCommand = cmd;换成cmd.Parameters["@username"].Value = username;
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
问题查明了原来是try的原因
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
[Quote=引用 11 楼 的回复:]

C# code
/// <summary>
/// 检测用户是否存在
/// </summary>
/// <param name="userName">登录帐号</param>
/// <param name="userPwd">登录密码</param>
/// <returns>如果存在返回true,否则返回false</returns>
……
[/Quote]尝试了,还是不行
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
不行啊,我直接把if (datarows== 0)
lblMessage.Text = "Incorrect user name";
改为
lblMessage.Text = "Incorrect user name";
if (datarows== 0)
;单击button还是没有"Incorrect user name"
但是我
放到protected void Button1_Click(object sender, EventArgs e)
{lblMessage.Text = "Incorrect user name";
单击button就OK!为什么?????????
licai1210 2012-06-03
  • 打赏
  • 举报
回复
    /// <summary>
/// 检测用户是否存在
/// </summary>
/// <param name="userName">登录帐号</param>
/// <param name="userPwd">登录密码</param>
/// <returns>如果存在返回true,否则返回false</returns>
public bool CheckLogin(string userName, string userPwd)
{
string constr = "Data Source=admin-pc;Initial Catalog=skyShark;Integrated Security=true";
string sql = "select count(*) from dtUsers where Username=@username and Password=@password";
SqlConnection con = new SqlConnection(constr);
SqlCommand cmd = new SqlCommand(sql, con);
cmd.Parameters["@username"].Value = userName;
cmd.Parameters["@password"].Value = userPwd;
con.Open();
int result = Convert.ToInt32(cmd.ExecuteScalar());
con.Close();
return (result > 0);
}
licai1210 2012-06-03
  • 打赏
  • 举报
回复

/// <summary>
/// 检测用户是否存在
/// </summary>
/// <param name="userName">登录帐号</param>
/// <param name="userPwd">登录密码</param>
/// <returns>如果存在返回true,否则返回false</returns>
public bool CheckLogin(string userName, string userPwd)
{
string constr = "Data Source=admin-pc;Initial Catalog=skyShark;Integrated Security=true";
string sql = "select count(*) from dtUsers" + "where Username=@username and Password=@password";
SqlConnection con = new SqlConnection(constr);
SqlCommand cmd = new SqlCommand(sql, con);
cmd.Parameters["@username"].Value = userName;
cmd.Parameters["@password"].Value = userPwd;
con.Open();
int result = Convert.ToInt32(cmd.ExecuteScalar());
con.Close();
return (result > 0);
}

//看看这个可以吗
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 的回复:]

也改成下面
SqlDataAdapter a = new SqlDataAdapter();
a.SelectCommand = cmd;
a.SelectCommand.Parameters["@username"].Value = username;
a.Fill(dataSet1, "dtUsers");
datarows = dataSet1.Tables[0].Row……
[/Quote]
嗯嗯,但还是没有incorrect user name
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
求解还是不行??
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Data;
using System.Web.Configuration;

namespace SkySharp
{
public partial class WebLogonForm : System.Web.UI.Page
{
string constr = "Data Source=admin-pc;Initial Catalog=skyShark;Integrated Security=true";

protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
using (SqlConnection con = new SqlConnection(constr))
{
try
{

DataSet dataSet1 = new DataSet();
string username, password;
int datarows;
con.Open();
SqlCommand cmd = new SqlCommand("select * from dtUsers" + "where Username=@username and Password=@password", con);



cmd.Parameters.Add(new SqlParameter("@username", SqlDbType.NVarChar, 15));
username = txtUserName.Text.Trim();
cmd.Parameters.Add("@password", SqlDbType.NVarChar, 15);
password = txtPassword.Text.Trim();
SqlDataAdapter a = new SqlDataAdapter();
a.SelectCommand = cmd;
a.SelectCommand.Parameters["@username"].Value = username;
a.Fill(dataSet1, "dtUsers");
datarows = dataSet1.Tables["dtUsers"].Rows.Count;
if (datarows== 0)
lblMessage.Text = "Incorrect user name";
else
{
if (dataSet1.Tables["dtUsers"].Rows[0][1].ToString().Trim() == password)
{
lblMessage.Text = "good";
}
else
lblMessage.Text = "Incorrect password";
}
}
catch (SqlException) { }
finally
{
con.Close();
}
}

}
}
}
蝶恋花雨 2012-06-03
  • 打赏
  • 举报
回复
也改成下面
SqlDataAdapter a = new SqlDataAdapter();
a.SelectCommand = cmd;
a.SelectCommand.Parameters["@username"].Value = username;
a.Fill(dataSet1, "dtUsers");
datarows = dataSet1.Tables[0].Rows.Count;
if (datarows==0)
lblMessage.Text = "Incorrect user name";
licai1210 2012-06-03
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 的回复:]
嗯,谢谢。倒过来OK了,现在输入数据库中不存在用户名却没有出现预期的incorre user name,请问哪里出错了?
[/Quote]

datarows = a.Fill(dataSet1, "dtUsers");
datarows = dataSet1.Tables["dtUsers"].Rows.Count;

多看看基础
蝶恋花雨 2012-06-03
  • 打赏
  • 举报
回复
dataSet1.Tables[0].Rows.Count 刚才手误。
蝶恋花雨 2012-06-03
  • 打赏
  • 举报
回复
判断if (datarows==0)

改成下面的

if(dataSet1.tables.rows.count==0)
lblMessage.Text = "Incorrect user name";
dylanliu9301 2012-06-03
  • 打赏
  • 举报
回复
嗯,谢谢。倒过来OK了,现在输入数据库中不存在用户名却没有出现预期的incorre user name,请问哪里出错了?

62,268

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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