我是新手,请大家帮我解决一个ASP.NET数据库连接问题.

时间:2021-08-13 13:14:48
我想用ASP.NET程序连接数据库,并且我已经有了这套程序,现在这套程序的功能就是:注册.商城和家族申请.
这个程序是用于游戏.注册是注册游戏帐号,商城是玩家购买游戏道具的,这个购买以后可以直接发放到玩家角色身上,家族申请是玩家申请一个组织,或者是一个团.这套程序全部可以实现,但是现在的问题是:我把数据库帐号密码包括连接数据名全部修改好了,注册用户出现问题,其他的我还没有试.出现的情况是:
“/”应用程序中的服务器错误。
--------------------------------------------------------------------------------

未将对象引用设置到对象的实例。 
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 

异常详细信息: System.NullReferenceException: 未将对象引用设置到对象的实例。

源错误: 


行 19:         string sfz = Request["sfz"];
行 20:         string vnum1 = Request["vnum"];
行 21:         string vnum2 = Session["VNum"].ToString();
行 22: 
行 23:         if (vnum1 != vnum2)
 

源文件: f:\qishi.zlfun.com\Register.aspx.cs    行: 21 

堆栈跟踪: 


[NullReferenceException: 未将对象引用设置到对象的实例。]
   Register.Page_Load(Object sender, EventArgs e) in f:\qishi.zlfun.com\Register.aspx.cs:21
   System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e) +14
   System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e) +35
   System.Web.UI.Control.OnLoad(EventArgs e) +99
   System.Web.UI.Control.LoadRecursive() +50
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +627

 


--------------------------------------------------------------------------------
版本信息: Microsoft .NET Framework 版本:2.0.50727.3053; ASP.NET 版本:2.0.50727.3053 

9 个解决方案

#1


请大哥大姐们帮我下,小弟感激不尽!

#2


Session["VNum"].不存在

#3


 Session["VNum"].ToString(); 
没有赋值就使用了找找 Session["VNum"]在那赋值的。

#4


Session["VNum"].ToString(); 
这个应该是验证码的位置吧,赋值这个东西我不懂,我是新手,接触.NET时间不长.这个游戏需要.net程序,现在都已经有了,我有个单独的注册页面,连接成功,并且可以注册,但是用这个就不知道怎么回事了.程序没有问题,也许是我那里没有设置好.我把Web.config贴出来,大哥大姐们研究下:
<?xml version="1.0" encoding="utf-8"?>
<!-- 
    注意: 除了手动编辑此文件以外,您还可以使用 
    Web 管理工具来配置应用程序的设置。可以使用 Visual Studio 中的
     “网站”->“Asp.Net 配置”选项。
    设置和注释的完整列表在 
    machine.config.comments 中,该文件通常位于 
    \Windows\Microsoft.Net\Framework\v2.x\Config 中
-->
<configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0">
  <appSettings>
    <add key="System_Conn1" value="Persist Security Info=True;Data Source=127.0.0.1;database=TAccount_test;UID=sa;Password=yaoool;" />
    <add key="System_Conn2" value="Persist Security Info=True;Data Source=127.0.0.1;database=TGame;UID=sa;Password=yaoool;" />
  </appSettings>
  <connectionStrings>
    <add name="public_UserConnectionString" connectionString="Data Source=127.0.0.1;Initial Catalog=TGame_Test;User ID=sa;Password=yaoool"
      providerName="System.Data.SqlClient" />
  </connectionStrings>
  <system.web>
    <!-- 
            设置 compilation debug="true" 将调试符号插入
            已编译的页面中。但由于这会 
            影响性能,因此只在开发过程中将此值 
            设置为 true。
        -->
    <compilation debug="true" />
    <!--
            通过 <authentication> 节可以配置 ASP.NET 使用的 
            安全身份验证模式,
            以标识传入的用户。 
        -->
    <authentication mode="Windows" />
    <!--
            如果在执行请求的过程中出现未处理的错误,
            则通过 <customErrors> 节可以配置相应的处理步骤。具体说来,
            开发人员通过该节可以配置
            要显示的 html 错误页
            以代替错误堆栈跟踪。

        <customErrors mode="RemoteOnly" defaultRedirect="GenericErrorPage.htm">
            <error statusCode="403" redirect="NoAccess.htm" />
            <error statusCode="404" redirect="FileNotFound.htm" />
        </customErrors>
        -->
  </system.web>
</configuration>

#5


Session["VNum"].ToString(); 
值为空  未将对象引用设置到对象的实例。 
  楼上所的  找到session赋值没有

#6


我是个.NET的小白,以前没有接触过ASP.NET,不知道session赋值在那里找...

#7


根据错误信息推断是 对象没有实例化导致的,与WebConfig没有关系。

这里来看应该是VNum的值没有保存在Session中. 
用CTRL + SHIFT + F在整个Solution中查找一下Session["VNum"]的位置, 看看它是在什么地方被赋值的

#8


所有的代码都在这:
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class Register : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        string username = Request["username"];
        string password = Request["password"];
        string password1 = Request["password1"];
        string sfz = Request["sfz"];
        string vnum1 = Request["vnum"];
        string vnum2 =  Session["VNum"].ToString();

        if (vnum1 != vnum2)
        {
            Display("验证码不一致!");
            return;
        }

        if (username == "" || username.Length < 4 || username.Length > 12)
        {
            Display("帐号位数不对!");
            return;
        }

        if (password == "" || password.Length < 4 || password.Length > 12)
        {
            Display("密码位数不对!");
            return;
        }

        if (password1 != password)
        {
            Display("2次密码不一致!");
            return;
        }

        if (sfz == "" || (sfz.Length != 15 && sfz.Length != 18))
        {
            Display("身份证位数不对!");
            return;
        }

        DataBase db = new DataBase();
        db.Connect();
        int ret = db.RegisterUser(username, password, sfz);
        db.DisConnect();
        
        switch(ret)
        {
            case -1:
                Display("帐号已经存在!");
                break;
            case -2:
                Display("提交出错!");
                break;
            case -99:
                Display("注册成功!");
                break;
        }
    }

    private void Display(string str)
    {
        this.ret.Text = str;
    }
}

只有一个位置.Session["VNum"]

#9


验证码:<input name="vnum" type="text" />
在HTML中,有个 验证码:<input name="vnum" type="text" />的提示,会不会跟这个有关?

#1


请大哥大姐们帮我下,小弟感激不尽!

#2


Session["VNum"].不存在

#3


 Session["VNum"].ToString(); 
没有赋值就使用了找找 Session["VNum"]在那赋值的。

#4


Session["VNum"].ToString(); 
这个应该是验证码的位置吧,赋值这个东西我不懂,我是新手,接触.NET时间不长.这个游戏需要.net程序,现在都已经有了,我有个单独的注册页面,连接成功,并且可以注册,但是用这个就不知道怎么回事了.程序没有问题,也许是我那里没有设置好.我把Web.config贴出来,大哥大姐们研究下:
<?xml version="1.0" encoding="utf-8"?>
<!-- 
    注意: 除了手动编辑此文件以外,您还可以使用 
    Web 管理工具来配置应用程序的设置。可以使用 Visual Studio 中的
     “网站”->“Asp.Net 配置”选项。
    设置和注释的完整列表在 
    machine.config.comments 中,该文件通常位于 
    \Windows\Microsoft.Net\Framework\v2.x\Config 中
-->
<configuration xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0">
  <appSettings>
    <add key="System_Conn1" value="Persist Security Info=True;Data Source=127.0.0.1;database=TAccount_test;UID=sa;Password=yaoool;" />
    <add key="System_Conn2" value="Persist Security Info=True;Data Source=127.0.0.1;database=TGame;UID=sa;Password=yaoool;" />
  </appSettings>
  <connectionStrings>
    <add name="public_UserConnectionString" connectionString="Data Source=127.0.0.1;Initial Catalog=TGame_Test;User ID=sa;Password=yaoool"
      providerName="System.Data.SqlClient" />
  </connectionStrings>
  <system.web>
    <!-- 
            设置 compilation debug="true" 将调试符号插入
            已编译的页面中。但由于这会 
            影响性能,因此只在开发过程中将此值 
            设置为 true。
        -->
    <compilation debug="true" />
    <!--
            通过 <authentication> 节可以配置 ASP.NET 使用的 
            安全身份验证模式,
            以标识传入的用户。 
        -->
    <authentication mode="Windows" />
    <!--
            如果在执行请求的过程中出现未处理的错误,
            则通过 <customErrors> 节可以配置相应的处理步骤。具体说来,
            开发人员通过该节可以配置
            要显示的 html 错误页
            以代替错误堆栈跟踪。

        <customErrors mode="RemoteOnly" defaultRedirect="GenericErrorPage.htm">
            <error statusCode="403" redirect="NoAccess.htm" />
            <error statusCode="404" redirect="FileNotFound.htm" />
        </customErrors>
        -->
  </system.web>
</configuration>

#5


Session["VNum"].ToString(); 
值为空  未将对象引用设置到对象的实例。 
  楼上所的  找到session赋值没有

#6


我是个.NET的小白,以前没有接触过ASP.NET,不知道session赋值在那里找...

#7


根据错误信息推断是 对象没有实例化导致的,与WebConfig没有关系。

这里来看应该是VNum的值没有保存在Session中. 
用CTRL + SHIFT + F在整个Solution中查找一下Session["VNum"]的位置, 看看它是在什么地方被赋值的

#8


所有的代码都在这:
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class Register : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        string username = Request["username"];
        string password = Request["password"];
        string password1 = Request["password1"];
        string sfz = Request["sfz"];
        string vnum1 = Request["vnum"];
        string vnum2 =  Session["VNum"].ToString();

        if (vnum1 != vnum2)
        {
            Display("验证码不一致!");
            return;
        }

        if (username == "" || username.Length < 4 || username.Length > 12)
        {
            Display("帐号位数不对!");
            return;
        }

        if (password == "" || password.Length < 4 || password.Length > 12)
        {
            Display("密码位数不对!");
            return;
        }

        if (password1 != password)
        {
            Display("2次密码不一致!");
            return;
        }

        if (sfz == "" || (sfz.Length != 15 && sfz.Length != 18))
        {
            Display("身份证位数不对!");
            return;
        }

        DataBase db = new DataBase();
        db.Connect();
        int ret = db.RegisterUser(username, password, sfz);
        db.DisConnect();
        
        switch(ret)
        {
            case -1:
                Display("帐号已经存在!");
                break;
            case -2:
                Display("提交出错!");
                break;
            case -99:
                Display("注册成功!");
                break;
        }
    }

    private void Display(string str)
    {
        this.ret.Text = str;
    }
}

只有一个位置.Session["VNum"]

#9


验证码:<input name="vnum" type="text" />
在HTML中,有个 验证码:<input name="vnum" type="text" />的提示,会不会跟这个有关?