通过ASP.net程序创建域帐户故障

时间:2010-03-09 11:59:37  来源:第二电脑网  作者:第二电脑网

  第二电脑网导读:诉我们,这是由于asp.net的权限不够,我们应该在asp.net模拟用户,这样就可以成功创建。      我将微软的相关文章摘录下来:            模拟 IIS 验证的帐户或用户      若要在收到 ASP.NET 应用程序中每个页的每个请求时模拟 Microsoft Internet 信...
  正文:我曾经成功地使用windows程序成功的创建了一批带邮箱的域帐户,但是,当我把这段代码交给我的一个同事(她负责开发Web应用)迁移到ASP/ target=_blank class=infotextkey>asp.net中后,只能创建域帐户,不能创建邮箱。为什么呢?
  
  我们咨询了微软的工程师,他告诉我们,这是由于asp.net的权限不够,我们应该在asp.net模拟用户,这样就可以成功创建。
  
  我将微软的相关文章摘录下来:
  
  
  
  模拟 IIS 验证的帐户或用户
  
  若要在收到 ASP.NET 应用程序中每个页的每个请求时模拟 Microsoft Internet 信息服务 (IIS) 身份验证用户,必须在此应用程序的 Web.config 文件中包含 <identity> 标记,并将 impersonate 属性设置为 true。例如:
  
  <identity impersonate="true" />
  
  
  为 ASP.NET 应用程序的所有请求模拟特定用户
  
  若要为 ASP.NET 应用程序的所有页面上的所有请求模拟特定用户,可以在该应用程序的 Web.config 文件的 <identity> 标记中指定 userName 和 password 属性。例如:
  
  <identity impersonate="true" userName="accountname" password="password" />
  
  
  注意:在线程上模拟特定用户的进程的标识必须具有“作为操作系统的一部分”权限。默认情况下,Aspnet_wp.exe 进程在名为 ASPNET 的计算机帐户下运行。不过,此帐户没有模拟特定用户所需的权限。如果您尝试模拟特定用户,则会出现一条错误信息。
  
  要解决此问题,请使用下列方法之一:
  
  •
  
  为 ASPNET 帐户(权限最低的帐户)授予“作为操作系统的一部分”权限。
  
  注意:虽然此方法可以解决问题,但 Microsoft 不建议使用此方法。
  
  •
  
  在 Machine.config 文件的 <processModel> 配置部分中,将运行 Aspnet_wp.exe 进程所使用的帐户更改为 System 帐户。
  
  在代码中模拟身份验证用户
  
  若要仅在运行代码特定部分时模拟身份验证用户 (User.Identity),您可以使用以下代码。此方法要求身份验证用户标识的类型为 WindowsIdentity。
  
  Visual Basic .NET
  
  Dim impersonationContext As System.Security.Principal.WindowsImpersonationContext
  Dim currentWindowsIdentity As System.Security.Principal.WindowsIdentity
  currentWindowsIdentity = CType(User.Identity, System.Security.Principal.WindowsIdentity)
  impersonationContext = currentWindowsIdentity.Impersonate()
  'Insert your code that runs under the security context of the authenticating user here.
  impersonationContext.Undo()
  
  
  Visual C# .NET
  
  System.Security.Principal.WindowsImpersonationContext impersonationContext;
  impersonationContext =
  ((System.Security.Principal.WindowsIdentity)User.Identity).Impersonate();
  //Insert your code that runs under the security context of the authenticating user here.
  impersonationContext.Undo();
  
  
  Visual J# .NET
  
  System.Security.Principal.WindowsImpersonationContext impersonationContext;
  impersonationContext =
  ((System.Security.Principal.WindowsIdentity)get_User().get_Identity()).Impersonate();
  //Insert your code that runs under the security context of the authenticating user here.
  impersonationContext.Undo();
  
  
  在代码中模拟特定用户
  
  若要仅在运行代码特定部分时模拟特定用户,请使用以下代码: 《通过ASP.net程序创建域帐户故障》由第二电脑网原创提供,转载请注明:http://www.002pc.com/master/College/Programming/aspnet/13152.html

 1/4    1 2 3 4 下一页 尾页


关键字:

关于《通过ASP.net程序创建域帐户故障》文章的评论

站内搜索: 高级搜索

热门搜索: Windows style 系统 tr IP QQ CPU 安装 function 注册 if td