SharePoint 改动passwordWeb Part部署方案
版权声明:本文为博主原创文章。未经博主同意不得转载。
https://blog.csdn.net/u012025054/article/details/31773231
SharePoint 改动passwordWeb Part部署方案
填写预调试网站,点击验证。验证成功后,选择“部署为场解决方式”。点击确定。
using System;
using System.ComponentModel;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls;
namespace changePWD.passwordChange
{
[ToolboxItemAttribute(false)]
public class passwordChange : WebPart
{
// 当更改可视 Web 部件项目项时,Visual Studio 可能会自己主动更新此路径。
private const string _ascxPath = @"~/_CONTROLTEMPLATES/changePWD/passwordChange/passwordChangeUserControl.ascx";
public string _domainName;
[Personalizable(PersonalizationScope.Shared)]
[WebBrowsable(true)]
[Category("自己定义设置")]
[WebDisplayName("请输入域server的计算机全名。
如smallville-pc")]
public string DomainName
{
get { return _domainName ?
? (_domainName = "smallville-pc"); }//这里是域名
set { _domainName = value; }
}
protected override void CreateChildControls()
{
Control control = Page.LoadControl(_ascxPath);
Controls.Add(control);
}
}
}
<%@ Assembly Name="$SharePoint.Project.AssemblyFullName$" %>
<%@ Assembly Name="Microsoft.Web.CommandUI, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="SharePoint" Namespace="Microsoft.SharePoint.WebControls" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="Utilities" Namespace="Microsoft.SharePoint.Utilities" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Register Tagprefix="asp" Namespace="System.Web.UI" Assembly="System.Web.Extensions, Version=3.5.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" %>
<%@ Import Namespace="Microsoft.SharePoint" %>
<%@ Register Tagprefix="WebPartPages" Namespace="Microsoft.SharePoint.WebPartPages" Assembly="Microsoft.SharePoint, Version=14.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c" %>
<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="passwordChangeUserControl.ascx.cs" Inherits="changePWD.passwordChange.passwordChangeUserControl" %>
更改password注意事项:
1.password必须包括下面三部分:字母,数字,特殊符号
2.password长度必须大于6位
3.新password不能与近期5次使用的password同样
4.一天之内仅仅同意改动一次password。
5.password改动后有5分钟的缓冲时间。5分钟后旧password作废。
6.发生更改password遗失,请联系系统管理员
7.联系邮箱ContactMe@126.com
username: | ||
输入旧password | ||
输入新password | ||
再次输入新password | ||
|
using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.Security;
using System.DirectoryServices.AccountManagement;
using Microsoft.SharePoint;
namespace changePWD.passwordChange
{
public partial class passwordChangeUserControl : UserControl
{
#region 字符串
string domainName = string.Empty;
string logName = string.Empty;
string splited = string.Empty;
#endregion
#region methods
protected void Page_Load(object sender, EventArgs e)
{
domainName = ((passwordChange)Parent).DomainName;
logName = SPContext.Current.Web.CurrentUser.LoginName;
if (logName.IndexOf("\\") >= 0)
{
splited = logName.Split('\\')[1];
}
SplitedLabel.Text = splited;
}
#region 主要功能实现
protected void OKButton_Click(object sender, EventArgs e)
{
string oldpwd = OldCode.Text;
string newpwd = NewCode2.Text;
OKButton.Page.Validate();
if (OKButton.Page.IsValid)
{
try
{
PrincipalContext context = new PrincipalContext(ContextType.Domain, domainName, splited, oldpwd);
UserPrincipal currentPrincipal = UserPrincipal.FindByIdentity(context, splited);
SPSecurity.RunWithElevatedPrivileges(delegate() //提升权限运行
{
currentPrincipal.ChangePassword(oldpwd, newpwd);
currentPrincipal.Save();
});
StaLabel.Text = "password改动成功";
}
catch (PasswordException pder)
{
StaLabel.Text = "PWD:[" + pder.Message + "]";
}
catch (Exception aner)
{
StaLabel.Text = "password改动错误:[" + aner.Message + "]";
}
}
else
{
StaLabel.Text = "按提示更改所填信息";
}
}
#endregion
protected void ClearButton_Click(object sender, EventArgs e)
{
OldCode.Text = string.Empty;
NewCode1.Text = string.Empty;
NewCode2.Text = string.Empty;
}
#endregion
}
}
6. 点击生成菜单。选择部署解决方式.
SharePoint 改动passwordWeb Part部署方案的更多相关文章
- redis从入门到放弃 -> 部署方案
单点部署方案 环境准备: [root@localhost ~]# cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) [root@ ...
- eql高可用部署方案
运行环境 服务器两台(后面的所有配置案例都是以10.96.0.64和10.96.0.66为例) 操作系统CentOS release 6.2 必须要有共同的局域网网段 两台服务器都要安装keepali ...
- virtual judge 本地部署方案
这是一种将自己的电脑当作服务器来部署一个vj的方法,我也是参考前辈们的做法稍作了改动,如果在服务器上部署的话需要在细节上稍作改动: 一.什么是Virtual Judge? vj的工作原理什么? vj ...
- Kubernetes常见的部署方案(十四)
一.常见的部署方案 滚动更新 服务不会停止,但是整个pod会有新旧并存的情况. 重新创建 先停止旧的pod,然后再创建新的pod,这个过程服务是会间断的. 蓝绿 (无需停机,风险较小) 部署v1的应用 ...
- Neutron 物理部署方案 - 每天5分钟玩转 OpenStack(68)
前面我们讨论了 Neutron 的架构,本节讨论 Neutron 的物理部署方案:不同节点部署不同的 Neutron 服务组件. 方案1:控制节点 + 计算节点 在这个部署方案中,OpenStack ...
- iOS应用动态部署方案
iOS的动态部署能极大的节约成本.苹果的审核周期很长,有的时候,你可能不得不等待将近2个星期去上架你的新功能或者bug.所以动态部署是有价值的. 我这里讨论的情况不把纯web应用考虑在内,因为用户体验 ...
- ActiveMQ实现负载均衡+高可用部署方案
一.架构和技术介绍 1.简介 ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线.完全支持JMS1.1和J2EE 1.4规范的JMS Provider实现 2.activemq的特 ...
- spring boot 自动部署方案
现在主流的自动部署方案大都是基于Docker的了,但传统的自动部署方案比较适合中小型公司,下面的方案就是比较传统的自动部署方案. 1.为什么需要自动部署 基于微服务的架构,自动部署显得非常重要.因为每 ...
- Memcached常规应用与分布式部署方案
1.Memcached常规应用 $mc = new Memcache(); $mc->conncet('127.0.0.1', 11211); $sql = sprintf("SELE ...
随机推荐
- vue中watch数组或者对象
1.普通的watch data() { return { frontPoints: 0 } }, watch: { frontPoints(newValue, oldValue) { console. ...
- 第三节:我的第一个Java程序
一.编写我的第一个Java程序流程: 1.新建一个文本文档:在电脑任意位置“右击”----->选择“新建”----->选择“文本文档”: 2.修改文档名与后缀名:“右击”新建的文本文档-- ...
- [LeetCode] Next Permutation(一种巧妙的解题方法)
Next Permutation Implement next permutation, which rearranges numbers into the lexicographically nex ...
- HDU 1016 S-Nim ----SG求值
S-Nim Time Limit : 5000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submiss ...
- 数据库连接池使用(一):使用C#数据库连接池
一.导读 使用C#数据库连接池,连接到数据库服务器通常由几个需要软长时间的步骤组成: 1.必须与服务器进行初次连接: 2.必须分析连接字符串信息: 3 ...
- ASP.NET MVC中你必须知道的13个扩展点
ScottGu在其最新的博文中推荐了Simone Chiaretta的文章13 ASP.NET MVC extensibility points you have to know,该文章为我 ...
- navicat 批量插入 测试数据
1. 前言 遇到线上大sql执行较慢, 10s+, 做优化改进时,首先想到的是在本地造出一个类似的库环境,先本地实验. 然后往表中创建大量数据... 2. 方案 利用mysql函数来插入大量数据 代码 ...
- ubuntu下使用python3的有些库时,解决"raise ImportError(str(msg) + ', please install the python3-tk package') ImportError: No module named '_tkinter', please install the python3-tk package"的错误
问题: 在Ubuntu下使用matplotlib这个库时,运行时出现如下错误: raise ImportError(str(msg) + ', please install the python3-t ...
- Transformation functionality for the String class
String类的转换功能: package com.itheima_05; /* * String类的转换功能: * char[] toCharArray():把字符串转换为字符数组 * String ...
- redis介绍(4)实战场景
redis我主要在两方面说明: 集群下的session的管理 Tomcat 与 DB之间缓存