windows - Windows Defender 将我的程序识别为多个木马(“Wacatac”和“Persistence”) - 可能是由覆盖注册表项引起的
问题描述
2个木马:
这是我认为导致问题的代码。目的是创建/修改注册表项以使程序在启动时运行:
void SoftwareDlg::SetSURegValue() {
string regSubKey("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run\\");
string regValueName = "Software";
string regValue = "D:\\Users\\Skew\\Documents\\repos\\Software\\Debug\\Software.exe"
try
{
size_t bufferSize = 0xFFF;
auto cbData = static_cast<DWORD>(regValue.size() * sizeof(char));
HKEY hKey;
DWORD position;
auto rc = RegCreateKeyEx(HKEY_CURRENT_USER, regSubKey.c_str(), 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hKey, &position);
if (position == REG_OPENED_EXISTING_KEY) {
DEBUG_PRINT("Key already exists & has been opened.")
}
else if (position == REG_CREATED_NEW_KEY) {
DEBUG_PRINT("Created new key.")
}
else {
DEBUG_PRINT("ERROR: Key does not exist, and a new key was not created.")
}
if (rc == ERROR_SUCCESS) {
auto rc = RegSetValueEx(hKey, regValueName.c_str(), 0, REG_SZ, (BYTE*)regValue.data(), cbData);
if (rc != ERROR_SUCCESS)
{
throw std::runtime_error("Windows system error code: " + to_string(rc));
}
}
else {
DEBUG_PRINT("Error opening key.\n")
}
}
catch (std::exception& e)
{
DEBUG_PRINT(e.what())
}
}
在我尝试解决这个问题的过程中,我开始测试创建/修改密钥的不同方案,但是当我意识到 Windows Defender 似乎停止将每次运行记录为“新威胁”并且似乎将它们作为一个单一的记录一起记录时,我的结果变得不确定我猜是“永久威胁”?不太确定。
话虽如此,当我最初创建密钥或打开它并为其分配相同的值时,Windows Defender 似乎没有记录威胁,但当我将程序移动到新目录时似乎确实记录了威胁(并且程序会尝试将“软件”注册表值的值更改为新的 EXE 位置)。
这给我留下了几个问题:
- 我的程序是否通过一些编码错误模仿了 2 个木马的行为?
- 或者我的机器上是否有一些潜在的、机会主义的恶意软件正在等待利用?
- 在尝试更改现有值之前是否需要删除它?的行为
RegCreateKeyEx
让我相信事实并非如此。 - 在没有提升权限的情况下写入注册表是禁忌吗?如果是这样...为什么我的机器让我这样做?
- 我在
RegSetValueEx()
函数中做了一些不正确的类型转换吗?
如果 #4 是这种情况,我想我真的很惊讶我收到了 Windows Defender 的通知,而不是 Visual Studio 或 UAC 提示。
解决方案
推荐阅读
- matlab - 我有 8 个类别,我需要使用 matlabta svm 代码对它们进行分类
- mysql - YII2 SQL:获取有条件的列数
- python - GUI 按钮卡住了
- c# - 在不同的服务器上连接 IIS
- c# - 通过 Ajax 快速设置 1000 条记录的值?
- php - Laravel Passport 不处理网站自己的 API 调用
- ruby-on-rails - Rails 应用程序中的 ActionView::Template::Error
- php - 我无法让文件获取内容链接 m3u8
- reactjs - 为什么不链接调度 Redux-Thunk
- ubuntu - 流浪汉与 ubuntu 16.04