isParameterTrue(string)
如果设置了指定的参数,则返回真,如果没有设置,则返回假。
清单 2 中的第一部分代码会检索不同的键值对,并将它们设置到 stateSaver 中。其中包括用户输入的数据库值,如服务器名、数据库名、用户 ID、密码和安装的目标目录。当然,在您想要卸载时,这些详细信息中有一些是至关重要的。您需要将在卸载过程中删除的数据库名称、它的连接字符串等。因此,为了保持安装的状态,所有这些 stateSaver 值都由安装程序储存在一个名为 *.installstate 的文件中。安装后,您可以在文件夹中查看该文件。按照这种方式使用文件使您能够避开注册表。另外,当您构建真正的安装程序时,最好明智地选择使用 stateSaver。如果某个用户在安装后删除了此文件,安装程序在在卸载过程中就会遇到问题。
清单 2 中的第二部分代码使用用户输入的值来检查数据库连接。如果用户没有输入用户 ID,此步骤就会对一个可信连接进行测试。这不是一个用来辨别集成模式验证选择或混合模式验证选择的简便方式。但是,现有用户界面编辑器中的限制又使得必须这样做。最终,此部分还会为数据库创建连接字符串。
清单 2 中的第三部分代码可在应用程序配置文件中设置连接字符串。此部分会将配置文件加载为一个 XML 文档,遍历到 connectionstring 节点,并设置该值。请注意将该文件的路径放在一起的方式。
清单 2 中的第四部分代码通过将运行脚本的任务委托给另一个类,来实际创建该数据库: DatabaseInstaller。
将 DatabaseInstaller.cs(下载资料中的示例文件)复制到您的项目中。DatabaseInstaller 具有两个构造函数来传递用户输入的数据库详细信息。另外,它还有一个私有构造函数,如清单 3 所示。
清单 3. 从嵌入式资源加载 InstallationFiles.xml。
文章来源于领测软件测试网 https://www.ltesting.net/