028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

Windows中怎么利用Telemetry实现权限维持

这篇文章将为大家详细讲解有关Windows中怎么利用Telemetry实现权限维持,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

创新互联公司是一家专业提供威远企业网站建设,专注与网站建设、成都做网站、HTML5、小程序制作等业务。10年已为威远众多企业、政府机构等服务。创新互联专业的建站公司优惠进行中。

大体步骤

如果你不想花时间了解该技术背后的原理,那你可以直接按照下列方法进行操作即可:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\AppCompatFlags\TelemetryController
schtasks /run /tn “\Microsoft\Windows\Application Experience\Microsoft Compatibility Appraiser”

为了方便大家理解,我们给出的注册表中的配置图,并将notepad.exe设置为自动运行目标:Windows中怎么利用Telemetry实现权限维持

技术原理

首先,“c:\windows\system32\CompatTelRunner.exe”是一个二进制文件,用来运行各种遥测任务。就其本身而言,二进制文件并不会收集太多数据。CompatTelRunner会检查一些系统信息,并确保网络已连接,然后通过运行各种命令来执行实际的遥测数据收集,我们可以把它想象成一个遥测管理器。

这个二进制文件似乎是为了易于扩展而创建的,而它将依赖于注册表来指示运行哪些命令。问题是,它将运行任何不受位置或类型限制的任意命令。乍一看,这可能是一个严重的安全问题,但我不认为是这样。如果您已经获得了对系统的管理访问权(执行此过程所必需的),那么您已经有了各种各样的选项可供利用。

当“CompatTelRunner.exe”(当前版本为2020年5月的版本)运行时,它首先会检查一些条件是否通过,然后再继续它的遥测任务。此时,必须满足下列条件之一:

有趣的是,这些检查是在Windows Server 2016发布后的某个时候添加的。在“CompatTelRunner.exe”更新之前,它并不会执行这些检测,而且无论目标Windows系统是什么版本,这个可执行文件都将运行注册表项中的命令。

检查执行完成后,命令行参数的存在与否将决定程序的运行模式,这里总共有三种运行模式,分别对应于一些不同的条件。

如果提供了指定DLL/函数的命令行参数,“CompatTelRunner.exe”将根据白名单列表来对它们进行验证。这将导致CompatTelRunner.exe”启动DLL provider并退出。如果没有提供DLL/函数名,程序将继续识别为运行模式。

如果存在HKEY U LOCAL U MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersion\AppCompatFlags\TelemetryController\OOBE并且未提供“-maintenance”参数,那么程序将以第二种模式-OOBE运行。这个注册表键会在检测完成之后被删除。如果提供了“-maintenance”参数,那么我们将验证是否可以运行并进入运行模式“0”。验证内容包括HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsNT\CurrentVersion\AppCompatFlags\TelemetryController\TestAllowRun设置为不为零的REG_DWORD或通过系统状态验证。

验证条件如下:

验证通过之后,程序将会把注册表键“RunsBlocked”的值重置为“0”.如果验证未通过,程序将会把注册表键“RunsBlocked”的值增加“1”。

如果没有传递命令行参数,那么“CompatTelRunner.exe”将会进入运行模式1(Nightly)。

运行模式识别完成后,程序还会对计划任务执行某些检测。接下来,程序将会在内部调用RunTelemetry,即执行遥测任务。

如果运行模式为0,那么程序还会执行额外的检测,如果这些检测均通过,或运行模式不为0,那么程序将会打开下列注册表项:

HKEY_LOCAL_MACHINE \SOFTWARE\Microsoft\WindowsNT\CurrentVersion\AppCompatFlags\TelemetryController

程序将会遍历该目录下的所有子健,然后在初始化调用中用它们来完成数据结构的填充:Windows中怎么利用Telemetry实现权限维持

接下来,我们的命令将会加载进如下所示的缓冲区结构中:

char command[520] = {0};

StringCchCatW(command, 260, L”%ls %ls%hs”, this->CommandStr, L”-cv”, );

根据程序的运行模式和计划任务调度模式,我们还可以在命令行中添加“-oobe”或“-fullsync”等参数。最后,这些命令将会以第二个参数传递给“CreateProcessW”,这相当于将其作为shell命令运行。

关于Windows中怎么利用Telemetry实现权限维持就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


名称栏目:Windows中怎么利用Telemetry实现权限维持
文章分享:http://www.tsicrk.com/article/gsdgoe.html

其他资讯

让你的专属顾问为你服务

1.0507s