出错信息:未将对象引用设置到对象的实例。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.NullReferenceException: 未将对象引用设置到对象的实例。源错误:
行 61: SqlCommand myCommand = new SqlCommand(str,myConnection);
行 62: myCommand.Parameters.Add(new SqlParameter("@ans",SqlDbType.NVarChar,2000));
行 63: myCommand.Parameters["@ans"].Value = answer.Text;
行 64: myCommand.Parameters.Add(new SqlParameter("@da",SqlDbType.NChar,50));
行 65: myCommand.Parameters["@da"].Value = DateTime.Now;
源文件: c:\inetpub\wwwroot\web\answermessage.aspx.cs 行: 63
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.NullReferenceException: 未将对象引用设置到对象的实例。源错误:
行 61: SqlCommand myCommand = new SqlCommand(str,myConnection);
行 62: myCommand.Parameters.Add(new SqlParameter("@ans",SqlDbType.NVarChar,2000));
行 63: myCommand.Parameters["@ans"].Value = answer.Text;
行 64: myCommand.Parameters.Add(new SqlParameter("@da",SqlDbType.NChar,50));
行 65: myCommand.Parameters["@da"].Value = DateTime.Now;
源文件: c:\inetpub\wwwroot\web\answermessage.aspx.cs 行: 63
是执行了NULL操作!!
SqlCommand myCommand = new SqlCommand(str,myConnection);
myCommand.Parameters.Add("@ans",SqlDbType.NVarChar,2000);
myCommand.Parameters[0].Value = answer.Text;
myCommand.Parameters.Add("@da",SqlDbType.NChar,50);
myCommand.Parameters[1].Value = DateTime.Now;
还是不行。
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;namespace Web
{
/// <summary>
/// answermessage 的摘要说明。
/// </summary>
public class answermessage : System.Web.UI.Page
{
protected System.Web.UI.WebControls.TextBox answer;
protected System.Web.UI.WebControls.RequiredFieldValidator Rfv_content;
protected System.Web.UI.WebControls.DataList DataList2;
public int key;
protected System.Web.UI.HtmlControls.HtmlForm Form1;
SqlConnection myConnection = new SqlConnection("server=(local);database=web;uid=sa;pwd=;");
private void Page_Load(object sender, System.EventArgs e)
{
if (Session["adminuser"] == null)
{
Response.Write("<script language=javascript>window.location.href='adminlogin.aspx'</script>");
Response.End();
} key = int.Parse((Request.QueryString["name"])); if (!IsPostBack)
{
ListBind();
}
}
private void ListBind()
{
string strSel="select * from messagelist where id='"+key+"'";
SqlDataAdapter MyAdapter = new SqlDataAdapter(strSel,myConnection);
DataSet ds = new DataSet();
MyAdapter.Fill(ds,"messagelist"); DataList2.DataSource=ds.Tables["messagelist"].DefaultView;
DataList2.DataBind();
}
public void Answer_Click(Object sender, EventArgs E)
{
string str="update messagelist set answer=@ans,adate=@da where id='"+key+"'";
SqlCommand myCommand = new SqlCommand(str,myConnection);
myCommand.Parameters.Add(new SqlParameter("@ans",SqlDbType.NVarChar,1000));
myCommand.Parameters["@ans"].Value = answer.Text;
myCommand.Parameters.Add(new SqlParameter("@da",SqlDbType.NChar,50));
myCommand.Parameters["@da"].Value = DateTime.Now; myCommand.Connection.Open(); myCommand.ExecuteNonQuery();
Response.Write("<script language=javascript>alert('回复留言成功!!!')</script>");
Response.End();
myCommand.Connection.Close();
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load); }
#endregion
}
}