国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 應(yīng)用 > 系統(tǒng)工具 > 正文

SharePoint2013 以其他用戶登錄和修改AD域用戶密碼的功能使用介紹

2020-07-10 20:36:02
字體:
供稿:網(wǎng)友

sharepoint默認是沒有修改AD密碼 和切換 用戶的功能,這里我用future的方式來實現(xiàn)。

部署wsp前:

部署后:

點擊以其他用戶身份登錄

點擊修改用戶密碼:

這里的擴展才菜單我們用CustomAction來實現(xiàn),我們需要添加空項目來部署它

以其他用戶身份登錄得xml如下:

修改用戶密碼的xml如下:

這里我們需要新建一個應(yīng)用程序頁面,首先需要添加路徑映射:

添加應(yīng)用程序頁面的代碼如下:


<%@ Assembly Name="$SharePoint.Project.AssemblyFullName___FCKpd___0quot; %><%@ Import Namespace="Microsoft.SharePoint.ApplicationPages" %><%@ Register Tagprefix="SharePoint" Namespace="Microsoft.SharePoint.WebControls" Assembly="Microsoft.SharePoint, Version=15.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %><%@ Register Tagprefix="Utilities" Namespace="Microsoft.SharePoint.Utilities" Assembly="Microsoft.SharePoint, Version=15.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %><%@ Register Tagprefix="asp" Namespace="System.Web.UI" Assembly="System.Web.Extensions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" %><%@ Import Namespace="Microsoft.SharePoint" %><%@ Assembly Name="Microsoft.Web.CommandUI, Version=15.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %><%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ChangePassword.aspx.cs" Inherits="SharePointProjectDemo.Layouts.ChangePassword.ChangePassword" DynamicMasterPageFile="~masterurl/default.master" %><asp:Content ID="PageHead" ContentPlaceHolderID="PlaceHolderAdditionalPageHead" runat="server"></asp:Content><asp:Content ID="Main" ContentPlaceHolderID="PlaceHolderMain" runat="server">     <asp:Literal ID="ltMsg" EnableViewState="false" runat="server"></asp:Literal><div>    <h3>        <span>修改密碼</span>    </h3>    <table width="400px">         <tr>            <td>               域            </td>            <td>                :            </td>            <td>                <asp:TextBox ID="txtdomain" runat="server" ></asp:TextBox>            </td>        </tr>         <tr>            <td>                舊密碼            </td>            <td>                :            </td>            <td>                <asp:TextBox ID="txtOld" runat="server" TextMode="Password"></asp:TextBox>            </td>        </tr>        <tr>            <td>                新密碼            </td>            <td>                :            </td>            <td>                <asp:TextBox ID="txtPass1" runat="server" TextMode="Password"></asp:TextBox>            </td>        </tr>        <tr>            <td>                確認新密碼            </td>            <td>                :            </td>            <td>                <asp:TextBox ID="txtPass2" runat="server" TextMode="Password"></asp:TextBox>            </td>        </tr>        <tr>            <td colspan="3" align="center">                <br />                <asp:Button ID="btnChangePwd" runat="server" Text="修改密碼" OnClick="btnChangePwd_Click" />            </td>        </tr>    </table>    <br />    <br /></div></asp:Content><asp:Content ID="PageTitle" ContentPlaceHolderID="PlaceHolderPageTitle" runat="server">修改密碼</asp:Content><asp:Content ID="PageTitleInTitleArea" ContentPlaceHolderID="PlaceHolderPageTitleInTitleArea" runat="server" >修改密碼</asp:Content>



using System;using Microsoft.SharePoint;using Microsoft.SharePoint.WebControls;using System.Security.Principal;using System.DirectoryServices.AccountManagement;namespace SharePointProjectDemo.Layouts.ChangePassword{    public class Impersonator    {        // Fields        private WindowsImpersonationContext ctx = null;        // Methods        public void BeginImpersonation()        {            try            {                if (!WindowsIdentity.GetCurrent().IsSystem)                {                    this.ctx = WindowsIdentity.Impersonate(WindowsIdentity.GetCurrent().Token);                    this.IsImpersonated = true;                }            }            catch            {                this.IsImpersonated = false;            }        }        public void StopImpersonation()        {            if (this.ctx != null)            {                this.ctx.Undo();            }        }        // Properties        public bool IsImpersonated        {            set;            get;        }    }    public partial class ChangePassword : LayoutsPageBase    {        protected void btnChangePwd_Click(object sender, EventArgs e)        {            string str = this.txtPass1.Text.Trim();            string str2 = this.txtPass2.Text.Trim();            string str3 = this.txtOld.Text.Trim();            string str4 = this.txtdomain.Text.Trim();            if (string.IsNullOrWhiteSpace(str4))            {                this.ltMsg.Text = "域不能為空!";            }            else if (string.IsNullOrWhiteSpace(str3))            {                this.ltMsg.Text = "舊密碼不能為空!";            }            else if (string.IsNullOrWhiteSpace(str))            {                this.ltMsg.Text = "新密碼不能為空!";            }            else if (str == str2)            {                this.ChangeUserPassword(this.txtPass2.Text.Trim(), str3, str4);            }            else            {                this.ltMsg.Text = "兩次新密碼不一致,請檢查!";            }        }        private void ChangeUserPassword(string NewPwd, string OldPwd, string domain)        {            try            {                Impersonator impersonator = new Impersonator();                impersonator.BeginImpersonation();                using (PrincipalContext context = this.GetPContext(OldPwd, domain))                {                    using (UserPrincipal principal = UserPrincipal.FindByIdentity(context, IdentityType.SamAccountName, GetLoginName()))                    {                        principal.ChangePassword(OldPwd, NewPwd);                    }                }                if (impersonator.IsImpersonated)                {                    impersonator.StopImpersonation();                    this.ltMsg.Text = "已成功修改密碼!";                }                else                {                    this.ltMsg.Text = "無法修改您的密碼,請聯(lián)系您的系統(tǒng)管理員!";                }            }            catch (Exception exception)            {                this.ltMsg.Text = exception.Message;            }        }        private string GetDomainContainter(string domain)        {            string str = string.Empty;            string[] strArray = domain.Split(new char[] { '.' }, StringSplitOptions.RemoveEmptyEntries);            foreach (string str2 in strArray)            {                str = str + "DC=" + str2 + ",";            }            if (str.Length > 0)            {                str = str.Substring(0, str.Length - 1);            }            return str;        }        private string GetLoginName()        {            string username= SPContext.Current.Web.CurrentUser.LoginName.Replace("i:0#.w|", "");            if(username.EndsWith(@"/system"))            {                username = username.Replace("system", "sherry");            }            return username;        }        private string GetLoginNameDomain()        {            string[] strArray = GetLoginName().Split(new char[] { '//' }, StringSplitOptions.RemoveEmptyEntries);            if (strArray.Length == 2)            {                return strArray[0];            }            return null;        }        private PrincipalContext GetPContext(string OldPwd, string domain)        {            return new PrincipalContext(ContextType.Domain, domain, this.GetDomainContainter(domain), ContextOptions.Negotiate, this.GetLoginName(), OldPwd);        }        protected void Page_Load(object sender, EventArgs e)        {            this.ltMsg.Text = GetLoginName().Replace("i:0#.w|", "");        }    }}
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄯善县| 扬州市| 南京市| 镇坪县| 南康市| 永安市| 湘乡市| 惠安县| 吉林省| 清苑县| 新龙县| 通河县| 九江县| 高安市| 辽宁省| 安图县| 克拉玛依市| 修武县| 安达市| 杭锦旗| 长春市| 瑞安市| 恩平市| 裕民县| 河间市| 浑源县| 精河县| 卫辉市| 新巴尔虎右旗| 七台河市| 西宁市| 石首市| 吉林市| 辽宁省| 宁远县| 乳源| 河池市| 上饶县| 华安县| 昂仁县| 宜昌市|