我正在使用SharePoint 2013 API将用户添加到不断增长的“网站eigenaren”,这意味着他们将获得对网站的完全控制权。 调用API后,它们在SP组的UI中可见,但是没有获得该组的权限。
当我通过用户界面从组中删除它们并再次使用用户界面添加它们时,他们将获得许可。 通过API添加用户时,还有其他要做的事情吗?
我添加用户的代码:
function addUserToGroup(contextWebInfo, groupName, username) {
console.log('Adding ' + username + ' to group ' + groupName);
return fetch(currentSiteUrl + "/_api/web/sitegroups/getbyname('" + groupName + "')/users", {
headers: new Headers({
Accept: 'application/json;odata=verbose',
'Content-Type': 'application/json;odata=verbose',
'X-RequestDigest': contextWebInfo.d.GetContextWebInformation.FormDigestValue
}),
credentials: 'include',
method: 'POST',
body: JSON.stringify({ '__metadata': { 'type': 'SP.User' }, 'LoginName': 'BIJTJES\\' + username })
}).then(function (response) {
if(response.ok){
console.log('User ' + username + ' added to group ' + groupName);
}else{
alert('Er is een fout opgetreden. Gelieve een melding op de SelfServiceDesk aan te maken met volgende tekst: Op site "' + currentSiteUrl + '" komt de foutmelding "' + response.error.message.value + '" bij het toevoegen van een lid aan de groep "' + groupName + '" als gebruiker "' + username + '"');
}
}).catch(function (error) { console.error('Error getting data:::', error); });
}
答案 0 :(得分:0)
我可以确认此问题,并且可以确认使用JSOM
而不是REST
时也是一个问题。
原来问题出在SharePoint使用声明时。这意味着,如果为REST api提供用户登录ID(域\用户),它将完全做到这一点。
但是,如果将“ i:0#.w|
”添加到用户ID ("i:0#.w|domain\user")
,则一切正常。