因为要做webpart权限判断所以决定用用户组来区分是否有权限,于是找到了几种方法。
这句是无敌的,因为这是判断当前用户是否是administratro组的用户,如果是当然是无所不能了
bool isSiteAdmin = SPContext.Current.Site.OpenWeb().CurrentUser.IsSiteAdmin;
一,直接得到当前用户然后遍历她的用户组集合。
string LogInanme = SPContext.Current.Site.OpenWeb().CurrentUser.LoginName;//得到当前用户名称,和这个功能没啥关系。
SPUser user = SPContext.Current.Site.OpenWeb().CurrentUser;//得到当前用户
foreach (SPGroup item in user.Groups)//遍历用户组取用户组名字来对应查看
{
string logname = item.LoginName;
}
二,是直接查询,不过没有他会直接报错所以要用try 来捕捉一下,但不用做其他处理。
try
{
SPGroup group = SPContext.Current.Site.OpenWeb().CurrentUser.Groups["aaaa"];
}
catch (Exception)
{
string text ="用户没有加入此用户组";
}
后来我又换了一种思路,让用户和webpart以及列表来关系上,也就是说用户对这个webpart是否有权限看这个用户是否是这个webpart的后台列表是否有权限,
因为我的webPart的数据都是从后台列表中取到的所以这样相当于把webpart的权限控制推到列表了
// 得到当前站点
SPSite currentSite = SPContext.Current.Site;
//当前页面
SPWeb currentWeb = currentSite.OpenWeb();
//当前用户
SPUser currentUser = currentWeb.CurrentUser;
//判断用户是否在sharepoint组里面
//提升权限
SPSecurity.RunWithElevatedPrivileges(
delegate()
{
//得到后台列表
SPList testList = currentWeb.GetList(currentSite.Url + "/Lists/ADTest/AllItems.aspx");
//判读该用户是否在该列表中有添加权限,(还有其他的几种查看,修改,删除等方法)
bool userPermission = testList.DoesUserHavePermissions(currentUser, SPBasePermissions.AddListItems);
});
这样就完全了