为了实现生日的SharePoint 2013应用程序,我需要从网站集中获取所有用户配置文件。为此,我想使用(或多个)客户端API。请参阅http://msdn.microsoft.com/en-us/library/jj163800.aspx#bkmk_APIversions。
不幸的是,我在API描述中找不到相当于Microsoft.Office.Server.UserProfiles
的内容。有Microsoft.SharePoint.Client.UserProfiles.PeopleManager
种方法GetUserProfilePropertiesFor
和GetUserProfilePropertyFor
,只有一个用户个人资料。
所以我的问题是:如何使用CSOM,JSOM,REST(或任何客户端技术)获取网站集中的所有用户配置文件?
答案 0 :(得分:4)
由于CSOM提供与人每用户范围相关的操作方法,因此您可以先使用SP.Web.siteUsers property检索所有网站用户。然后使用
SP.UserProfiles.PeopleManager.getUserProfilePropertyFor Method获取BirthDay
财产,如下所示:
//Get Birthday User Profile Property for Site Users
function getUsersBirthdays(Success,Error) {
var clientContext = new SP.ClientContext.get_current();
var web = clientContext.get_web();
var users = web.get_siteUsers();
clientContext.load(users);
clientContext.executeQueryAsync(
function() {
var peopleManager = new SP.UserProfiles.PeopleManager(clientContext);
var personsProperties = [];
for(var i = 0; i < users.get_count();i++)
{
var user = users.getItemAtIndex(i);
var personBirthday = peopleManager.getUserProfilePropertyFor(user.get_loginName(),'SPS-Birthday');
personsProperties.push(personBirthday);
}
clientContext.executeQueryAsync(
function() {
Success(personsProperties);
},
Error);
},
Error);
}
//Usage
var scriptbase = _spPageContextInfo.webAbsoluteUrl + '/_layouts/15/';
$.getScript(scriptbase + 'SP.js', function () {
$.getScript(scriptbase + 'SP.UserProfiles.js', function () {
getUsersBirthdays(function(usersProperties){
for(var i = 0; i < usersProperties.length;i++)
{
console.log(usersProperties[i].get_value());
}
},
function(sender,args){
console.log(args.get_message());
});
});
});
答案 1 :(得分:1)
This也适用于SP2013
function GetUsersGroups(){
ClientContext context = new Microsoft.SharePoint.Client.ClientContext("http://SPSite");
GroupCollection groupCollection = context.Web.SiteGroups;
context.Load(groupCollection,
groups = > groups.Include(group = > group.Users));
context.ExecuteQuery();
foreach (Group group in groupCollection)
{
UserCollection userCollection = group.Users;
foreach (User user in userCollection)
{
MessageBox.Show("User Name: " + user.Title + " Email: " + user.Email + " Login: " + user.LoginName);
}
}
//Iterate the owners group
Group ownerGroup = context.Web.AssociatedOwnerGroup;
context.Load(ownerGroup);
context.Load(ownerGroup.Users);
context.ExecuteQuery();
foreach (User ownerUser in ownerGroup.Users)
{
MessageBox.Show("User Name: " + ownerUser.Title + " Email: " + ownerUser.Email + " Login: " + ownerUser.LoginName);
}
context.Dispose();
}