asp.net(C#)读取域名服务器AD帐号

c#源码:

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

using System.Security.Principal;
using System.Runtime.InteropServices;
using System.Data.SqlClient;
using System.Web.SessionState;

public partial class login : System.Web.UI.Page
{
    String str_userId = "";
    String str_userName = "";
    String str_name = "";
    String str_email = "";
     string str_shenfen = "";

    public const int LOGON32_LOGON_INTERACTIVE = 2;
    public const int LOGON32_PROVIDER_DEFAULT = 0;
    WindowsImpersonationContext impersonationContext;
    [DllImport("advapi32.dll")]
    public static extern int LogonUserA(String lpszUserName,
    String lpszDomain,
    String lpszPassword,
    int dwLogonType,
    int dwLogonProvider,
    ref IntPtr phToken);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    public static extern int DuplicateToken(IntPtr hToken,
    int impersonationLevel, ref IntPtr hNewToken);
    [DllImport("advapi32.dll", CharSet = CharSet.Auto, SetLastError = true)]
    public static extern bool RevertToSelf();
    [DllImport("kernel32.dll", CharSet = CharSet.Auto)]
    public static extern bool CloseHandle(IntPtr handle);
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void btnok_Click(object sender, EventArgs e)
    {
        ///如果页面输入合法
        if (Page.IsValid == true)
        {   ///定义类并获取用户的登陆信息  
            // if (impersonateValidUser(Convert.ToString(txteid.Text.Trim()), "your domain", Convert.ToString(txtpsw.Text.Trim())))
          //   {
                      IISAuthUser = Convert.ToString(txteid.Text.Trim());

            IUser user = new User();
            SqlDataReader recu = user.GetUserLoginL(IISAuthUser);
            ///判断用户是否合法
            if (recu.Read())
            {
                str_userId = recu["UserID"].ToString();
                str_userName = recu["UserName"].ToString();
                str_name = recu["Name"].ToString();
                str_email = recu["email"].ToString();
                str_shenfen = recu["shenfen"].ToString();
               Label1.Text = "欢迎您,   " + str_name;
            }


            recu.Close();

            ///验证用户合法性,并跳转到系统平台
            if ((str_userId != null) && (str_userId != ""))
            {
                Session["UserID"] = str_userId;
                Session["UserName"] = str_userName;
                Session["Name"] = str_name;
                Session["email"] = str_email;
                Session["shenfen"] = str_shenfen;


                switch (Convert.ToString(Session["shenfen"]))
                {
                    case "staffer":
                        Session["title"] = "Fill In Purchase Order";
                        Response.Redirect("~/main.aspx?gl=apply");
                        break;
                    default:

                        Session["title"] = "Approve Purchase Order";
                        Response.Redirect("~/approve.aspx");
                        break;
                }
            }
            else
            {
                Label1.Text = "无授权用户,请联系IT部开通!";
            }
            //
        }
        else
        {
                      Label1.Text = "无网络帐号,请联系IT部申请开通!";
        }
    //    }
    }
    private bool impersonateValidUser(String userName, String domain, String password)
    {
        WindowsIdentity tempWindowsIdentity;
        IntPtr token = IntPtr.Zero;
        IntPtr tokenDuplicate = IntPtr.Zero;
        if (RevertToSelf())
        {
            if (LogonUserA(userName, domain, password, LOGON32_LOGON_INTERACTIVE,
            LOGON32_PROVIDER_DEFAULT, ref token) != 0)
            {
                if (DuplicateToken(token, 2, ref tokenDuplicate) != 0)
                {
                    tempWindowsIdentity = new WindowsIdentity(tokenDuplicate);
                    impersonationContext = tempWindowsIdentity.Impersonate();
                    if (impersonationContext != null)
                    {
                        CloseHandle(token);
                        CloseHandle(tokenDuplicate);
                        return true;
                    }
                }
            }
        }
        if (token != IntPtr.Zero)
            CloseHandle(token);
        if (tokenDuplicate != IntPtr.Zero)
            CloseHandle(tokenDuplicate);
        return false;
    }
    private void undoImpersonation()
    {
        impersonationContext.Undo();
    }
}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值