NullReferenceException我熟悉它们,但在这种情况下无法解决

时间:2014-04-06 17:36:40

标签: c# asp.net sql nullreferenceexception sqlconnection

我对ASP.net相当新,但我熟悉Null引用异常但是我无法解决这个问题。我试图从webform收集数据并通过连接字符串传递给我的数据库,这是发生异常的时候。

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.Configuration;


public partial class Register : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        try
        {
            if (IsPostBack)
            {
                SqlConnection studConnA = new SqlConnection(ConfigurationManager.ConnectionStrings["StudConnection"].ConnectionString);
                studConnA.Open();
                string checkuser = "select count(*) from StudTable where Name='" + TextBoxName.Text + "'";
                SqlCommand studComA = new SqlCommand(checkuser, studConnA);
                int temp = Convert.ToInt32(studComA.ExecuteScalar().ToString());
                if (temp == 1)
                {
                    Response.Write("User already Exists");
                }
                studConnA.Close();
            }

        }
        catch (Exception ex)
        {
            Response.Write("Error:" + ex.ToString());
        }
    }


    protected void Button1_Click(object sender, System.EventArgs e)
    {
        try
        {
            SqlConnection studConn = new SqlConnection(ConfigurationManager.ConnectionStrings["StudConnectionString"].ConnectionString);
            studConn.Open();
            string insertQuery = "insert into StudTable (Name,Email,Age,Continent,School,Password) values (@name,@email,@age,@cont,@school,@pass)";
            SqlCommand studCom = new SqlCommand(insertQuery, studConn);
            studCom.Parameters.AddWithValue("@name", TextBoxName.Text);
            studCom.Parameters.AddWithValue("@email", TextBoxEmail.Text);
            studCom.Parameters.AddWithValue("@age", TextBoxAge.Text);


studCom.Parameters.AddWithValue("@cont",DropDownCont.SelectedItem.ToString());
            studCom.Parameters.AddWithValue("@school", TextBoxSchool.Text);
            studCom.Parameters.AddWithValue("@pas", TextBoxPass.Text);

            studCom.ExecuteNonQuery();
            Response.Redirect("Backend.aspx");
            Response.Write("Your Registration is Sucessful");

            studConn.Close();
        }
        catch (Exception ex)
        {
            Response.Write("Error:" +ex.ToString());
        }
    }
}

空引用发生在第19行

Line 17:                 if (IsPostBack)
Line 18:                 {
Line 19:                     SqlConnection studConnA = new SqlConnection(ConfigurationManager.ConnectionStrings["StudConnection"].ConnectionString);
Line 20:                     studConnA.Open();
Line 21:                     string checkuser = "select count(*) from StudTable where Name='" + TextBoxName.Text + "'";

我认为问题在于我的连接字符串的语法,但我不确定,

任何人都可以帮我解决这个问题吗?

2 个答案:

答案 0 :(得分:1)

检查配置文件以获取以下密钥:

<connectionStrings>
 <add name="StudConnection" connectionString="YOUR DETAILS" />
</connectionStrings>

如果不存在,请添加右键并重试。

您还可以使用以下代码检查问题:

   if (IsPostBack)
    {
        // if this line fails, then you don't have the proper connection string
        // element in the config file.
        Debug.Assert(ConfigurationManager.ConnectionStrings["StudConnection"] != null);

        SqlConnection studConnA = new SqlConnection(ConfigurationManager.ConnectionStrings["StudConnection"].ConnectionString);
        studConnA.Open();
        string checkuser = "select count(*) from StudTable where Name='" + TextBoxName.Text + "'";
        SqlCommand studComA = new SqlCommand(checkuser, studConnA);
        int temp = Convert.ToInt32(studComA.ExecuteScalar().ToString());
        if (temp == 1)
        {
            Response.Write("User already Exists");
        }
        studConnA.Close();
    }

答案 1 :(得分:0)

似乎没有配置名为StudConnection的连接字符串。