winforms アプリケーションの管理者グループに IUSR アカウントを追加したいと考えています。次のコードは、「NT AUTHORITY\IUSR」のユーザーが見つからないため失敗します。
DirectoryEntry AD = new DirectoryEntry("WinNT://" + Environment.MachineName + ",computer");
DirectoryEntry administrators = AD.Children.Find("Administrators", "group");
DirectoryEntry iusr = AD.Children.Find(@"NT AUTHORITY\IUSR", "user");
administrators.Invoke("Add", new object[] {iusr.Path.ToString()});
これは悪い考えだと思います。これを行っているのは、IIS7 で開発目的のみに新しい Web サイトをプログラムで作成する winforms アプリケーションを作成しているためです。Web サイトは正常に作成されていますが、ページを読み込もうとすると ASP.NET が「アクセスが拒否されました」というエラーを表示します。IUSR を管理者グループに追加すると、すべて正常に動作します。他に何を試すことができますか?以下は、新しいウェブサイトを作成するために使用しているコードです。
Site site = servermgr.Sites.Add(websitename, physicalpath, port);
Binding binding = site.Bindings.CreateElement();
string bindinginfo = "*:" + port.ToString() + ":" + hostipaddress;
binding.Protocol = "http";
binding.BindingInformation = bindinginfo;
site.Bindings.Clear();
site.Bindings.Add(binding);
site.Applications.Add(applicationpath, applicationphysicalpath);
site.ApplicationDefaults.ApplicationPoolName = "Default";
servermgr.CommitChanges();