[玩转系统] SharePoint Online:使用 PowerShell 的独特权限报告
作者:精品下载站 日期:2024-12-14 21:10:46 浏览:16 分类:玩电脑
SharePoint Online:使用 PowerShell 的独特权限报告
要求:使用 PowerShell 在 SharePoint Online 中获取唯一权限报告。
SharePoint Online 独特权限报告的 PowerShell
在 SharePoint Online 中,跟踪分配给每个网站、列表和库的权限非常重要。然而,这可能是一项艰巨的任务,尤其是在大型且复杂的环境中。独特的权限报告提供了分配给 SharePoint Online 网站中每个项目的权限的清晰、简洁的概述,从而更轻松地管理权限并确保符合安全策略。
要使用此 PowerShell 在 SharePoint Online 中查找唯一权限,请设置 $SiteURL 和 $ReportFile 参数并运行此脚本。它会生成一个 CSV 文件,其中包含给定网站集中具有唯一权限的所有网站、列表和列表项。以下是用于获取唯一权限的 SharePoint Online PowerShell:
#Load SharePoint CSOM Assemblies
Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\ISAPI\Microsoft.SharePoint.Client.dll"
Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\ISAPI\Microsoft.SharePoint.Client.Runtime.dll"
#Function to Get Unique Permission from a Web and its contents - recursively
Function Get-SPOUniquePermissionReport([Microsoft.SharePoint.Client.Web]$Web)
{
Write-host -f Yellow "`nSearching Unique Permissions on the Site:"$web.Url
#Check if the given site is using unique permissions
$Web.Retrieve("HasUniqueRoleAssignments")
$Ctx.ExecuteQuery()
#Get the Root Web
$RootWeb = $ctx.site.RootWeb
$Ctx.Load($RootWeb)
$Ctx.ExecuteQuery()
### Check if the web has broken inheritance
If($Web.HasUniqueRoleAssignments -and $Web.ID -ne $RootWeb.ID)
{
#Get Object Details and Send the Data to Report file
$ObjectName = $Web.Title ;$ObjectType = "Sub Site" ; $ObjectURL = $Web.URL
"$($ObjectName) `t $($ObjectURL) `t $($ObjectType)" | Out-File $CSVFile -Append
Write-host -f Green "`t Unique Permissions Found on Site:" $Web.URL
}
### Get unique permission in Lists
Write-host -f Yellow "`t Searching Unique Permissions on the Lists..."
$Lists = $Web.Lists
$Ctx.Load($Lists)
$Ctx.ExecuteQuery()
#Exclude system lists
$ExcludedLists = @("App Packages","appdata","appfiles","Apps in Testing","Cache Profiles","Composed Looks","Content and Structure Reports","Content type publishing error log","Converted Forms",
"Device Channels","Form Templates","fpdatasources","Get started with Apps for Office and SharePoint","List Template Gallery", "Long Running Operation Status","Maintenance Log Library", "Style Library",
,"Master Docs","Master Page Gallery","MicroFeed","NintexFormXml","Quick Deploy Items","Relationships List","Reusable Content","Search Config List", "Solution Gallery", "Site Collection Images",
"Suggested Content Browser Locations","TaxonomyHiddenList","User Information List","Web Part Gallery","wfpub","wfsvc","Workflow History","Workflow Tasks", "Preservation Hold Library")
#Iterate through each list
ForEach($List in $Lists)
{
$Ctx.Load($List)
$Ctx.ExecuteQuery()
If($ExcludedLists -NotContains $List.Title -and $List.Hidden -eq $false)
{
#Check if the given site is using unique permissions
$List.Retrieve("HasUniqueRoleAssignments")
$Ctx.ExecuteQuery()
#Check if List has unique permissions
If($List.HasUniqueRoleAssignments)
{
#Send Data to CSV File
$ObjectTitle = $List.Title
$ObjectURL = $("{0}{1}" -f $Web.Url.Replace($Web.ServerRelativeUrl,''), $List.RootFolder.ServerRelativeUrl)
$ObjectType = "List/Library"
"$($ObjectTitle) `t $($ObjectURL) `t $($ObjectType)" | Out-File $CSVFile -Append
Write-host -f Green "`t`tUnique Permissions Found on the List: '$($List.Title)'"
}
Write-host -f Yellow "`t`t Searching Unique Permissions on the Lists Items of '$($List.Title)'"
#Query to get list items in batches
$Query = New-Object Microsoft.SharePoint.Client.CamlQuery
$Query.ViewXml = "<View Scope='RecursiveAll'><RowLimit>2000</RowLimit></View>"
### Get unique permission on List items
Do {
#Get all items from the list
$ListItems = $List.GetItems($Query)
$Ctx.Load($ListItems)
$Ctx.ExecuteQuery()
$Query.ListItemCollectionPosition = $ListItems.ListItemCollectionPosition
#Loop through each List item
ForEach($ListItem in $ListItems)
{
$ListItem.Retrieve("HasUniqueRoleAssignments")
$Ctx.ExecuteQuery()
If ($ListItem.HasUniqueRoleAssignments -eq $true)
{
#Send Data to CSV File
$ObjectType = "List Item/Folder"
#Get the URL of the List Item
$ListItem.ParentList.Retrieve("DefaultDisplayFormUrl")
$Ctx.ExecuteQuery()
$DefaultDisplayFormUrl = $ListItem.ParentList.DefaultDisplayFormUrl
$ObjectURL = $("{0}{1}?ID={2}" -f $Web.Url.Replace($Web.ServerRelativeUrl,''), $DefaultDisplayFormUrl,$ListItem.ID)
$ObjectTitle = $ListItem["Title"]
"$($ObjectTitle) `t $($ObjectURL) `t $($ObjectType)" | Out-File $CSVFile -Append
Write-host -ForegroundColor Green "`t`t`t Unique Permissions Found on Item ID:" $ListItem.ID
}
}
} While ($Query.ListItemCollectionPosition -ne $null)
}
}
#Process each subsite in the site
$Subsites = $Web.Webs
$Ctx.Load($Subsites)
$Ctx.ExecuteQuery()
Foreach ($SubSite in $Subsites)
{
#Call the function Recursively
Get-SPOUniquePermissionReport($Subsite)
}
}
#Config Parameters
$SiteURL= "https://crescent.sharepoint.com/sites/marketing"
$CSVFile = "C:\Temp\UniquePermissionsRpt.csv"
#Get Credentials to connect
$Cred = Get-Credential
Try {
#Setup the context
$Ctx = New-Object Microsoft.SharePoint.Client.ClientContext($SiteURL)
$Ctx.Credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($Cred.UserName,$Cred.Password)
#Get the Web
$Web = $Ctx.Web
$Ctx.Load($Web)
$Ctx.ExecuteQuery()
#Write CSV (TAB Separated) File Header
"Title `t URL `t Object" | Out-File $CSVFile
#Call the function to get unique permissions from the site collection
Get-SPOUniquePermissionReport $Web
}
Catch {
write-host -f Red "Error:" $_.Exception.Message
}
此 PowerShell 脚本可获取给定网站集中权限继承已损坏的对象列表,例如网站、列表或库、列表项。如果您想要获取有关谁有权访问哪些内容的报告,请使用此 PowerShell 脚本:SharePoint Online:使用 PowerShell 的网站集权限报告。
总之,使用 PowerShell 在 SharePoint Online 中生成唯一的权限报告是一个简单的过程,可以通过使用上面解释的 PowerShell 脚本来完成。通过使用 PowerShell cmdlet 检索网站中每个项目的权限,您可以快速创建提供 SharePoint Online 网站全面概述的报告。
如果您需要查找具有唯一权限的子网站、列表和库或列表项,请使用以下脚本:
- SharePoint Online:使用 PowerShell 查找具有唯一权限的所有网站
- SharePoint Online:使用 PowerShell 查找具有唯一权限的所有列表
- SharePoint Online:使用 PowerShell 获取具有唯一权限的所有列表项
猜你还喜欢
- 03-30 [玩转系统] 如何用批处理实现关机,注销,重启和锁定计算机
- 02-14 [系统故障] Win10下报错:该文件没有与之关联的应用来执行该操作
- 01-07 [系统问题] Win10--解决锁屏后会断网的问题
- 01-02 [系统技巧] Windows系统如何关闭防火墙保姆式教程,超详细
- 12-15 [玩转系统] 如何在 Windows 10 和 11 上允许多个 RDP 会话
- 12-15 [玩转系统] 查找 Exchange/Microsoft 365 中不活动(未使用)的通讯组列表
- 12-15 [玩转系统] 如何在 Windows 上安装远程服务器管理工具 (RSAT)
- 12-15 [玩转系统] 如何在 Windows 上重置组策略设置
- 12-15 [玩转系统] 如何获取计算机上的本地管理员列表?
- 12-15 [玩转系统] 在 Visual Studio Code 中连接到 MS SQL Server 数据库
- 12-15 [玩转系统] 如何降级 Windows Server 版本或许可证
- 12-15 [玩转系统] 如何允许非管理员用户在 Windows 中启动/停止服务
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[影视] 黑道中人 Alto Knights(2025)剧情 犯罪 历史 电影
[古装剧] [七侠五义][全75集][WEB-MP4/76G][国语无字][1080P][焦恩俊经典]
[实用软件] 虚拟手机号 电话 验证码 注册
[电视剧] 安眠书店/你 第五季 You Season 5 (2025) 【全10集】
[电视剧] 棋士(2025) 4K 1080P【全22集】悬疑 犯罪 王宝强 陈明昊
[软件合集] 25年6月5日 精选软件22个
[软件合集] 25年6月4日 精选软件36个
[短剧] 2025年06月04日 精选+付费短剧推荐33部
[短剧] 2025年06月03日 精选+付费短剧推荐25部
[软件合集] 25年6月3日 精选软件44个
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电视剧] 欢乐颂.5部全 (2016-2024)
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[影视] 【稀有资源】香港老片 艺坛照妖镜之96应召名册 (1996)
[剧集] 神经风云(2023)(完结).4K
[剧集] [BT] [TVB] [黑夜彩虹(2003)] [全21集] [粤语中字] [TV-RMVB]
[实用软件] 虚拟手机号 电话 验证码 注册
[资源] B站充电视频合集,包含多位重量级up主,全是大佬真金白银买来的~【99GB】
[影视] 内地绝版高清录像带 [mpg]
[书籍] 古今奇书禁书三教九流资料大合集 猎奇必备珍藏资源PDF版 1.14G
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电影] 美国队长4 4K原盘REMUX 杜比视界 内封简繁英双语字幕 49G
[电影] 死神来了(1-6)大合集!
[软件合集] 25年05月13日 精选软件16个
[精品软件] 25年05月15日 精选软件18个
[绝版资源] 南与北 第1-2季 合集 North and South (1985) /美国/豆瓣: 8.8[1080P][中文字幕]
[软件] 25年05月14日 精选软件57个
[短剧] 2025年05月14日 精选+付费短剧推荐39部
[短剧] 2025年05月15日 精选+付费短剧推荐36部
- 最新评论
-
- 热门tag