转自:http://weblogs.3322.org/
做的一个程序中要求ASP.net 程序可以使用已经存在的域用户来登录(而且为了与其它程序界面一致一定要使用 Forms 登录),查找了一些相关的资料发现还是可以实现的。
主要还是依靠 advapi32.dll 中的 LogonUser API 函数。
using System.Web.Security;
using System.Runtime.InteropServices;
[DllImport("advapi32.dll", CharSet=CharSet.Auto)]
public static extern int LogonUser(String lpszUserName,
String lpszDomain,
String lpszPassword,
int dwLogonType,
int dwLogonProvider,
ref IntPtr phToken);
public const int LOGON32_LOGON_INTERACTIVE = 2;
public const int LOGON32_PROVIDER_DEFAULT = 0;
void Login_Click(Object sender, EventArgs E)
{
IntPtr token = IntPtr.Zero;
if(LogonUser(UserName.Value,
UserDomain.Value,
UserPass.Value,
LOGON32_LOGON_INTERACTIVE,
LOGON32_PROVIDER_DEFAULT,
ref token) != 0)
{
FormsAuthentication.RedirectFromLoginPage(UserName.Value,
PersistCookie.Checked);
}
else
{
lblResults.Text = "Invalid Credentials: Please try again";
}
}
其它方面的使用与普通的forms 程序没有太大的区别,也许还有更好的方法。
分享到:
相关推荐
.net 用域账号登录开发系统, Ad登录,域账号登。
LDAP实现AD域账号验证
使用基於 active directory 用戶登錄的FORM 驗證,並且能過配置machineKey 實現SSO 單點登錄
VB.NET WEB开发使用AD域用户名和密码登录
使用AD登录时,参数可不用设置用户名、密码。
验证AD域账号登陆,获取AD域用户列表,获取用户邮箱,修改密码等AD域操作
验证AD域用户登录 ,传入用户名(userName)和密码(password)进行验证。
MOSS 2007 AD认证进行表单登录的方法
系统集成中关于实现AD域登录的代码,方便调用,在企业级开发中经常用到的
AD技巧之指定用户登录和指定计算机登陆
AD域-限制windows域用户多点并发登录
如何使用AD9361,以及相关的参数配置问题
AD组策略使用技巧-使用AD组策略实现统一桌面和屏保
ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库ad元件库...
通过本脚本可直接把AD域帐号的信息及状态直接自动生成csv文件,可显示字段有:“姓名,AD帐号,描述信息,邮件,邮编,传真,密码输错次数,登录次数,禁用状态,锁定状态,最后修改时间,66048密码不过期状态,对象...
AD无用的计算机账号删除工具
用户登录域,提示当前所用为临时配置账户,可尝试次解决方法。
java 基于NTLM协议集成AD账号域登录 内含JAR包,DEMO包以及说明文档
这是用java连接window server 的Acitive Directory进行用户登陆验证的代码,里面用的是用户名的登陆名进行验证,也可以是用户的其他信息(如邮箱等)进行验证。
详细分析AD账号 lockout的几种可能性 制定相关解决方案对账号进行解锁。