0

我的场景是我在我的开发机器上创建了一个 VB.NET 应用程序,现在希望使用包和部署向导将它分发到另一台机器上。

开发机器上的代码完美运行,但是当我将它安装在目标机器上时,它给出了一个空引用异常。

我在目标机器上有一个访问数据库,它是我在我的开发机器上使用的数据库的精确副本。我的连接字符串在我的 app.config 文件中定义,我不知道如何继续。

这是我的 app.config 文件,其中包含我的连接字符串:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
</configSections>
<connectionStrings>
  <add name="connString"
       connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\Users\Dave\Documents\duraGadget.mdb"
       providerName="System.Data.OleDb" />
</connectionStrings>
<startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0,Profile=Client" />
</startup>
</configuration>

这是我的 Form1 加载(根据错误消息出现空指针):

 Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

    constring = ConfigurationManager.ConnectionStrings("connString").ConnectionString()

    Dim sql As String = "SELECT * FROM duragadget ORDER BY skuNo ASC"
    Dim connection As New OleDbConnection(constring)
    Dim dataadapter As New OleDbDataAdapter(sql, connection)
    Dim ds As New DataSet()
    connection.Open()
    dataadapter.Fill(ds, "dura")
    connection.Close()
    DataGridView1.DataSource = ds
    DataGridView1.DataMember = "dura"

    DataGridView1.Columns(1).Width = 125
    DataGridView1.Columns(2).Width = 125
    DataGridView1.Columns(3).Width = 125
    DataGridView1.Columns(4).Width = 125
    DataGridView1.Columns(5).Width = 5000

End Sub

这是目标机器上错误消息框对话框中显示的错误消息:

有关调用即时 (JIT) 调试而不是此对话框的详细信息,请参阅此消息的末尾。

** * **异常文本** * **** System.NullReferenceException:对象引用未设置为对象的实例。在 DuraGadget.Form1.Form1_Load(Object sender, EventArgs e) 在 System.EventHandler.Invoke(Object sender, EventArgs e) 在 System.Windows.Forms.Form.OnLoad(EventArgs e) 在 System.Windows.Forms.Form.OnCreateControl () 在 System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible) 在 System.Windows.Forms.Control.CreateControl() 在 System.Windows.Forms.Control.WmShowWindow(Message& m) 在 System.Windows.Forms.Control .WndProc(Message& m) 在 System.Windows.Forms.ScrollableControl.WndProc(Message& m) 在 System.Windows.Forms.Form.WmShowWindow(Message& m) 在 System.Windows.Forms.Form.WndProc(Message& m) 在 System .Windows.Forms.Control.ControlNativeWindow.OnMessage(Message& m) 在 System.Windows.Forms.Control。

** * **加载的程序集** * **** mscorlib 程序集版本:4.0.0.0 Win32 版本:4.0.30319.296 (RTMGDR.030319-2900)

代码库:file:///c:/WINDOWS/Microsoft.NET/Framework/v4.0.30319/mscorlib.dll

DuraGadget 程序集版本:1.0.0.0 Win32 版本:1.0.0.0

代码库:file:///C:/Program%20Files/Default%20Company%20Name/DSN%20new%20Upgrade/DuraGadget.exe

Microsoft.VisualBasic 程序集版本:10.0.0.0 Win32 版本:10.0.30319.1 构建者:RTMRel

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/Microsoft.VisualBasic/v4.0_10.0.0.0__b03f5f7f11d50a3a/Microsoft.VisualBasic.dll

系统组装版本:4.0.0.0 Win32 版本:4.0.30319.1001 构建者:RTMGDR

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System/v4.0_4.0.0.0__b77a5c561934e089/System.dll

System.Core 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1 构建者:RTMRel

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Core/v4.0_4.0.0.0__b77a5c561934e089/System.Core.dll

System.Windows.Forms 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1002 构建者:RTMGDR

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Windows.Forms/v4.0_4.0.0.0__b77a5c561934e089/System.Windows.Forms.dll

System.Drawing 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1001 构建者:RTMGDR

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Drawing/v4.0_4.0.0.0__b03f5f7f11d50a3a/System.Drawing.dll

System.Runtime.Remoting 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1 (RTMRel.030319-0100)

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Runtime.Remoting/v4.0_4.0.0.0__b77a5c561934e089/System.Runtime.Remoting.dll

System.Data 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1 (RTMRel.030319-0100)

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_32/System.Data/v4.0_4.0.0.0__b77a5c561934e089/System.Data.dll

System.Configuration 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1 (RTMRel.030319-0100)

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Configuration/v4.0_4.0.0.0__b03f5f7f11d50a3a/System.Configuration.dll

System.Xml 程序集版本:4.0.0.0 Win32 版本:4.0.30319.1 构建者:RTMRel

代码库:file:///C:/WINDOWS/Microsoft.Net/assembly/GAC_MSIL/System.Xml/v4.0_4.0.0.0__b77a5c561934e089/System.Xml.dll

** * **即时调试** * **** 要启用即时 (JIT) 调试,此应用程序或计算机 (machine.config) 的 .config 文件必须在 system.windows.forms 部分中设置 jitDebugging 值。还必须在启用调试的情况下编译应用程序。

例如:

启用 JIT 调试后,任何未处理的异常都将发送到计算机上注册的 JIT 调试器,而不是由该对话框处理。

4

2 回答 2

1

这是连接字符串中的来源:

Data Source=C:\Users\Dave\Documents\duraGadget.mdb

您机器上 exe 的路径:

C:/Program Files/Default Company Name/DSN new Upgrade/DuraGadget.exe

很可能无法打开 duraGadget 文件,因为指定文件夹(在目标计算机上)中不存在,因为 C:\Users\Dave 目录完全不存在。你说的是Windows XP,XP没有C:\Users文件夹。是的。更新连接字符串的路径。

于 2013-04-09T23:49:52.150 回答
0

伙计们感谢您的所有建议。经过数小时的工作后,我最终破解了它。这是一个组合。对于处于类似情况的任何人,请通过右键单击您的项目文件夹...属性使用发布选项,然后通过发布向导发布一键部署。另外我正在使用不同的数据库。拆分数据库给我带来了麻烦,在我的情况下不需要。更改这些问题以及在我的 app.config 中声明单个连接字符串,以及确保正确设置我的数据集连接字符串 最终对其进行排序,我现在可以将其安装在 XP...Win7 等上。

于 2013-04-10T22:40:54.750 回答