[玩转系统] 团队审核 – 不再有范围蔓延或团队蔓延
作者:精品下载站 日期:2024-12-14 05:33:52 浏览:12 分类:玩电脑
团队审核 – 不再有范围蔓延或团队蔓延
您想了解有关使用 PowerShell 监控 Microsoft Teams 的更多信息吗?了解如何随时间检查设置以检查更改。防止(或解决)配置漂移。
从哪儿开始
范围蔓延、配置蔓延和团队蔓延都有一个共同的根本问题——缺乏监控或控制来防止这些变化。在本文中,我们将讨论如何使用 PowerShell 来监视团队及其配置并确定已发生的更改。由于 Teams 的规模和复杂性,我们不会涵盖每个配置方面,而是通过演练一些如何使用 PowerShell 的示例来设置管理员以获得成功。对此的灵感来自于被称为配置分析器的安全中心,它有一个漂移分析和历史选项卡。
初始点
与使用任何 PowerShell 脚本或工具一样,请确保您的 Microsoft Teams PowerShell 模块正在运行最新版本:
Update-Module MicrosoftTeams
然后关闭您的 PowerShell 会话,因为这可以确保下次加载 PowerShell 模块时,它将是最新版本。
验证您的版本是最新的:
Import-Module MicrosoftTeams
Get-Module MicrosoftTeams
再次比较可用的版本号(此处)。
使用什么 cmdlet
构建自定义脚本来审核 Microsoft Teams 配置可以纯粹使用 Get-* cmdlet 来完成,因为这些是发现 PowerShell cmdlet,可查询设置和对象并提供所需的详细信息。可以通过以下一行找到这些内容的快速列表(连接到 Microsoft Teams PowerShell 端点后):
Get-Command Get-* |
Where Source -eq MicrosoftTeams |
Sort Name |
ft Name
我们不会逐一审查可用的 cmdlet,因为其中有超过 150 个,但我们将审查一些选定的示例,以帮助发现 Teams 中的重要项目以“审核”设置。
Microsoft Teams 和 Teams 渠道
队伍名单
跟踪团队的数量和类型是审核 Teams 配置的一个重要方面,因为 Teams 可能会超出组织打算创建或维护的范围。通过验证团队数量,我们可以在数量失控之前看到增长和使用情况。首先,查询队伍数量:
(Get-Team).Count
应该显示类似的结果:
Get-Team | ft DisplayName,Visibility,Archived,GroupId
团队频道列表
每个团队可以有一个或多个渠道来跟踪:
Get-Team |
ForEach-Object {Write-Host $_.DisplayName -ForegroundColor Yellow ;Get-TeamChannel -GroupID $_.GroupID |
ft DisplayName,Membership*,Description}
使用上面的 PowerShell cmdlet,我们能够收集有关 Teams 环境的大量数据和设置。我们如何使用这些数据来真正审核环境?其一,我们可以监控 Teams 和 Teams 频道的蔓延。在下面的示例中,我们每月检查 Teams 和 Teams 频道,看看发生了什么变化:
例子
首次检查团队和频道的数量时,可能有 35 个团队和 56 个频道,然后当再次运行 cmdlet 时(也许一个月后),这些数字可能会增加到 40 和 65。我们可以像这样提取初始计数:
# Team count
(Get-Team).Count
# Teams channel count
Get-Team |
Foreach-Object {$Channels = (Get-TeamChannel -GroupID $_.GroupID).Count;$TeamsChannelCount=$TotalChannels+$Channels}
稍后,我们可以按计划再次以编程方式检查这些数字:
$TeamsCount = (Get-Team).Count
Get-Team |
Foreach-Object {$Channels = (Get-TeamChannel -GroupID $_.GroupID).Count;$TeamsChannelCount=$TotalChannels+$Channels}
报告-现实世界的例子
当我们想要开始审核 Teams 和 Teams 频道的数量时,我们需要一种方法来存储计数并将这些计数与 Teams 中的当前数量进行比较。
第一次运行:
# Date column
$CurrentMonth = Get-Date -Format "MM.yyyy"
# File header
"Date,TeamsCount,TeamsChannelCount" |
Out-File 'TeamsAndChannelCounts.csv'
# First month counts
$TeamsCount = (Get-Team).Count
Get-Team |
Foreach-Object {$Channels = (Get-TeamChannel -GroupID $_.GroupID).Count;$TeamsChannelCount=$TotalChannels+$Channels}
$Output = "$CurrentMonth,$TeamsCount,$TeamsChannelCount" |
Out-File 'TeamsAndChannelCounts.csv' -Append
我们有数据行的预定运行可以检查差异:
# Import data
$TeamsData = Import-Csv .\TeamsAndChannelCounts.csv
# Last line
$CurrentMonth = $TeamsData[-1]
# Next to last line to compare
$LastMonth = $TeamsData[-2]
# Check each Teams data point for change
If ($CurrentMonth.TeamsCount -gt $LastMonth.TeamsCount) {Write-Host 'There are new Teams present.'}
If ($CurrentMonth.TeamsChannelCount -gt $LastMonth.TeamsChannelCount) {Write-Host 'There are new Teams Channels present.'}
如果我们需要深入了解一下,我们还可以检查自上次以来哪些团队是新的。为此,我们可以第一次运行它:
Get-Team |
select DisplayName,Visibility,GroupId,Archived,Description |
Export-Csv -Path HistoricalTeams.csv
每个月我们都可以检查更改:
Get-Team |
select DisplayName,Visibility,GroupId,Archived,Description |
Export-Csv -Path CurrentTeams.csv
然后我们可以使用Compare-Object来比较这两个文件:
$Historical = Get-Content .\HistoricalTeams.csv
$Current = Get-Content .\CurrentTeams.csv
Compare-Object -ReferenceObject $Historical -DifferenceObject $Current
我们在此示例中看到有两个不同的组,它们是新的,因为 SideIndicator 值指向 $Current 变量中的文件数据。
我们还可以使用 PowerShell 执行另一步骤,将历史团队文件替换为当前文件,以便我们随时可以比较最新的计数:
Remote-Item HistoricalTeams.csv
Rename-Item CurrentTeams.csv HistoricalTeams.csv
访客访问
在团队内,可以控制您的来宾有权访问的内容,我们可以使用 PowerShell 控制这些设置。一般来说,监视来宾用户的 Teams 配置方面是 Teams 配置安全性的一个重要方面。因此,我们可以使用 PowerShell 来探索这一点,看看我们可以发现和监控什么。
首先是 PowerShell cmdlet:
Get-Command Get-*team*guest*
它提供了这些 cmdlet:
Get-CsTeamsGuestCallingConfiguration
Get-CsTeamsGuestMeetingConfiguration
Get-CsTeamsGuestMessagingConfiguration
其中每一项都将揭示配置的不同方面。使用 PowerShell,我们可以记录并比较更改的设置,就像我们对团队和频道所做的那样。
访客呼叫配置
首先,让我们分解基本的访客呼叫配置:
$CurrentMonth = Get-Date -Format "MM.yyyy"
$GuestCallingCfg = (Get-CsTeamsGuestCallingConfiguration).AllowPrivateCalling
$FileHeader = "Date,AllowPrivateCalling" |
Out-File 'GuestCallingConfiguration.csv'
$Output = "$CurrentMonth,$GuestCallingCfg" |
Out-File 'GuestCallingConfiguration.csv' -append
这里只有一个重要值。我们可以验证这不会随着时间的推移而发生变化,我们必须每月、每季度等运行一次:
$CurrentMonth = Get-Date -Format "MM.yyyy"
$GuestCallingCfg = (Get-CsTeamsGuestCallingConfiguration).AllowPrivateCalling
$FileHeader = "Date,AllowPrivateCalling" |
Out-File 'GuestCallingConfiguration.csv'
$Output = "$CurrentMonth,$GuestCallingCfg" |
Out-File 'GuestCallingConfiguration-current.csv' -append
然后我们可以像这样比较两个输出文件:
$Historical = Import-Csv GuestCallingConfiguration.csv
$Current = Import-Csv GuestCallingConfiguration-current.csv
$Historical.AllowPrivateCalling -eq $Current.AllowPrivateCalling
如果发生更改,结果将如下所示:
来宾会议配置
接下来,我们有访客会议配置,其中包含更多要管理的设置。首先,我们需要创建我们今天配置的基线或发现:
第一次运行:
# Discover current configuration
$GuestMeeting = Get-CsTeamsGuestMeetingConfiguration |
Select AllowIPVideo,ScreenSharingMode,AllowMeetNow,LiveCaptionsEnabledType,AllowTranscription
# Create a Hash table output to be exported
$Hashtable = New-Object System.Collections.Hashtable
$Hashtable['AllowIPVideo'] = $GuestMeeting.AllowIPVideo
$Hashtable['ScreenSharingMode'] = $GuestMeeting.ScreenSharingMode
$Hashtable['AllowMeetNow'] = $GuestMeeting.AllowMeetNow
$Hashtable['LiveCaptionsEnabledType'] = $GuestMeeting.LiveCaptionsEnabledType
$Hashtable['AllowTranscription'] = $GuestMeeting.AllowTranscription
# Export $Hashtable variable to a CSV for comparison
$HashTable.GetEnumerator() |
Select-Object -Property Key,Value |
Export-Csv -NoTypeInformation -Path GuestMeeting.csv
然后,随着时间的推移,我们可以进行后续运行[每月、每季度、每年],这将使用上面相同的代码,但将输出文件更改为“GuestMeeting-Current.csv”:
$HashTable.GetEnumerator() |
Select-Object -Property Key,Value |
Export-Csv -NoTypeInformation -Path GuestMeeting-Current.csv
比较两种配置:
# Compare the original and current CSV files
$CSV1 = Get-Content .\GuestMeeting.csv
$CSV2 = Get-Content .\GuestMeeting-Current.csv
Compare-Object $CSV1 $CSV2
如果检测到差异,我们应该看到如下内容:
访客消息配置
也可以使用访客消息配置执行相同的过程。对于第一次运行,我们可以使用以下代码:
# Discover current configuration
$GuestMessaging = Get-CsTeamsGuestMessagingConfiguration |
Select AllowUserEditMessage,AllowUserDeleteMessage,AllowUserDeleteChat,AllowUserChat,AllowGiphy,GiphyRatingType,AllowMemes,AllowImmersiveReader,AllowStickers
# Create a Hash table output to be exported
$Hashtable = New-Object System.Collections.Hashtable
$Hashtable['AllowUserEditMessage'] = $GuestMessaging.AllowUserEditMessage
$Hashtable['AllowUserDeleteMessage'] = $GuestMessaging.AllowUserDeleteMessage
$Hashtable['AllowUserDeleteChat'] = $GuestMessaging.AllowUserDeleteChat
$Hashtable['AllowUserChat'] = $GuestMessaging.AllowUserChat
$Hashtable['AllowGiphy'] = $GuestMessaging.AllowGiphy
$Hashtable['GiphyRatingType'] = $GuestMessaging.GiphyRatingType
$Hashtable['AllowMemes'] = $GuestMessaging.AllowMemes
$Hashtable['AllowImmersiveReader'] = $GuestMessaging.AllowImmersiveReader
$Hashtable['AllowStickers'] = $GuestMessaging.AllowStickers
# Export $Hashtable variable to a CSV for comparison
$HashTable.GetEnumerator() |
Select-Object -Property Key,Value |
Export-Csv -NoTypeInformation -Path GuestMessaging.csv
后续运行:[每月、每季度、每年]
使用上面相同的代码,但将输出文件更改为“GuestMessaging-Current.csv”:
$HashTable.GetEnumerator() |
Select-Object -Property Key,Value |
Export-Csv -NoTypeInformation -Path GuestMessaging-Current.csv
比较:
# Compare the original and current CSV files
$CSV1 = Get-Content .\GuestMessaging.csv$CSV2 = Get-Content .\GuestMessaging-Current.csv
Compare-Object $CSV1 $CSV2
如果检测到差异,我们应该看到如下内容:
请注意,在上面的比较中,两个值已更改:AllowMemes 和 AllowStickers,并且通过指示符 (==>),新配置现在为 'True' 对于这两个设置,而原始配置 (
猜你还喜欢
- 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