Webセットアッププロジェクトがあります。セットアップでは、ユーザーが接続文字列を挿入できる入力フィールドがあります。セットアップを実行すると、次のエラーが発生します。
エラー1001。不明なエラー(0x8000x5000)
エラーが存在する場所を追跡するために、ファイルを作成し、すべてのメソッドでこのファイルに何かを書き込みます。今、私はこの行によってエラーが発生したと思います:
string friendlySiteName = entry.Properties["ServerComment"].Value.ToString();
しかし、私はこの問題を修正する方法がわかりません。あなたが私を助けてくれることを願っています!
コード:
public override void Install(System.Collections.IDictionary stateSaver)
{
base.Install(stateSaver);
// Retrieve configuration settings
string targetSite = Context.Parameters["targetsite"];
string targetVDir = Context.Parameters["targetvdir"];
string targetDirectory = Context.Parameters["targetdir"];
string targetConnectionString = Context.Parameters["targetconn"];
FileStream f = new FileStream("c:\\myfile.txt", FileMode.OpenOrCreate, FileAccess.ReadWrite);
StreamWriter w = new StreamWriter(f);
w.WriteLine("targetSite: " + targetSite);
w.WriteLine("targetVDir: " + targetVDir);
w.WriteLine("targetDirectory: " + targetDirectory);
w.WriteLine("targetConnectionString: " + targetConnectionString);
w.Close();
w.Dispose();
f.Close();
f.Dispose();
ConfigureWebConfig(targetSite, targetVDir, targetConnectionString);
}
void ConfigureWebConfig(string targetSite, string targetVDir, string targetConn)
{
try
{
// Retrieve "Friendly Site Name" from IIS for TargetSite
DirectoryEntry entry = new DirectoryEntry("IIS://LocalHost/" + targetSite);
FileStream f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
StreamWriter w = new StreamWriter(f);
w.WriteLine("In ConfigureWebConfig stap 1 ");
w.Close();
w.Dispose();
f.Close();
f.Dispose();
string friendlySiteName = entry.Properties["ServerComment"].Value.ToString();
f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
w = new StreamWriter(f);
w.WriteLine("In ConfigureWebConfig friendlySiteName: " + friendlySiteName);
w.Close();
w.Dispose();
f.Close();
f.Dispose();
// Open Application's Web.Config
Configuration config = WebConfigurationManager.OpenWebConfiguration("/" + targetVDir, friendlySiteName);
addConnectionStringAttribute(targetConn, config);
f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
w = new StreamWriter(f);
w.WriteLine("In ConfigureWebConfig stap 2 ");
w.Close();
w.Dispose();
f.Close();
f.Dispose();
// togleCompilationAttribute(config);
// Persist web.config settings
config.Save();
f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
w = new StreamWriter(f);
w.WriteLine("In ConfigureWebConfig stap 3 ");
w.Close();
w.Dispose();
f.Close();
f.Dispose();
}
catch (Exception)
{
throw;
}
}
private static void addConnectionStringAttribute(string connectionStringValue, Configuration config)
{
ConnectionStringSettings appDatabase = new ConnectionStringSettings();
appDatabase.Name = "dataConnectionString";
appDatabase.ConnectionString = connectionStringValue;
appDatabase.ProviderName = "System.Data.SqlClient";
FileStream f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
StreamWriter w = new StreamWriter(f);
w.WriteLine("In addConnectionStringAttribute stap 1 ");
w.Close();
w.Dispose();
f.Close();
f.Dispose();
config.ConnectionStrings.ConnectionStrings.Clear();
config.ConnectionStrings.ConnectionStrings.Add(appDatabase);
f = new FileStream("c:\\myfile.txt", FileMode.Append, FileAccess.Write);
w = new StreamWriter(f);
w.WriteLine("In addConnectionStringAttribute stap 2 ");
w.Close();
w.Dispose();
f.Close();
f.Dispose();
}