最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

关于惠普笔记本音频驱动存在内置键盘记录器后门漏洞的安全公告_

IT圈 admin 36浏览 0评论

2023年12月17日发(作者:大令羽)

关于惠普笔记本音频驱动存在内置键盘记录器后门漏洞的安全公告

安全公告编号:CNTA-2017-0053

近期,国家信息安全漏洞共享平台(CNVD)收录了惠普笔记本音频驱动内置键盘记录器后门漏洞 (CNVD-2017-09590,对应编号CVE-2017-8360)。攻击者可利用在当前用户会话中运行的任何进程监控调试信息,记录用户通过键盘输入的任意内容,包括用户输入的密码等敏感数据,构成较为严重的信息泄露和运行安全风险。

一、漏洞情况分析

2017年4月28日,瑞士安全公司Modzero的安全研究员Thorsten Schroeder在审查WindowsActive Domain的基础设施时发现,惠普IT产品(笔记本电脑)中的Conexant音频驱动程序内置了用于调试产品的(键盘记录器),可记录用户的所有按键输入。在原出厂环境下,与Conexant音频驱动程序包被同时安装在笔记本电脑中,键盘记录功能除了处理快捷键/功能键的点击事件外,所有的键盘输入信息都会被写入所有用户权限都可读的路径中的日志文件(C:)中,甚至会传递给OutputDebugStringAPI,这使得任何可以调用MapViewOfFile API的框架或者进程都能够通过用户的键盘输入信息静默的收集敏感数据,并在白名单机制下绕过杀毒软件检测。

CNVD对漏洞的综合评级为“高危”。

二、漏洞影响范围

受漏洞影响的硬件产品型号:

HP EliteBook 820 G3 Notebook PC

HP EliteBook 828 G3 Notebook PC

HP EliteBook 840 G3 Notebook PC

HP EliteBook 848 G3 Notebook PC

HP EliteBook 850 G3 Notebook PC

HP ProBook 640 G2 Notebook PC

HP ProBook 650 G2 Notebook PC

HP ProBook 645 G2 Notebook PC

HP ProBook 655 G2 Notebook PC

HP ProBook 450 G3 Notebook PC

HP ProBook 430 G3 Notebook PC

HP ProBook 440 G3 Notebook PC

HP ProBook 446 G3 Notebook PC

HP ProBook 470 G3 Notebook PC

HP ProBook 455 G3 Notebook PC

HP EliteBook 725 G3 Notebook PC

HP EliteBook 745 G3 Notebook PC

HP EliteBook 755 G3 Notebook PC

HP EliteBook 1030 G1 Notebook PC

HP ZBook 15u G3 Mobile Workstation

HP Elite x2 1012 G1 Tablet

HP Elite x2 1012 G1 with Travel Keyboard

HP Elite x2 1012 G1 Advanced Keyboard

HP EliteBook Folio 1040 G3 Notebook PC

HP ZBook 17 G3 Mobile Workstation

HP ZBook 15 G3 Mobile Workstation

HP ZBook Studio G3 Mobile Workstation

HP EliteBook Folio G1 Notebook PC

受漏洞影响的操作系统:

Microsoft Windows 10 32

Microsoft Windows 10 64

Microsoft Windows 10 IOT Enterprise 32-Bit (x86)

Microsoft Windows 10 IOT Enterprise 64-Bit (x86)

Microsoft Windows 7 Enterprise 32 Edition

Microsoft Windows 7 Enterprise 64 Edition

Microsoft Windows 7 Home Basic 32 Edition

Microsoft Windows 7 Home Basic 64 Edition

Microsoft Windows 7 Home Premium 32 Edition

Microsoft Windows 7 Home Premium 64 Edition

Microsoft Windows 7 Professional 32 Edition

Microsoft Windows 7 Professional 64 Edition

Microsoft Windows 7 Starter 32 Edition

Microsoft Windows 7 Ultimate 32 Edition

Microsoft Windows 7 Ultimate 64 Edition

Microsoft Windows Embedded Standard 7 32

Microsoft Windows Embedded Standard 7E 32-Bit

注:其它使用了Conexant硬件和驱动器的硬件厂商也有可能受该问题影响。

三、漏洞修复建议

惠普针对该情况紧急发布过一个关闭此调试功能的修复程序。2017年5月14日,惠普又发布了更新的修复驱动程序,该程序能将所有高保真音频驱动中有此调试记录功能的源代码删除。受影响的惠普电脑对应修复程序的列表请参考惠普官网:/us-en/document/c05519670

如未能升级,可以采用如下临时解决方案:

删除MicTray可执行文件和相应的日志记录文件。仅仅删除计划任务是不能解决问题的,因为Windows服务CxMonSvc将再一次启动MicTray。删除文件位置如下:

可执行文件的位置:C:

日志文件的位置:C:

附:参考链接:

/t5/HP-newsroom-blog/Modzero-report-on-keylogger-issue/ba-p/937?from=groupmessage

/advisories/

/flaw/show/CNVD-2017-09590

int64 keylogger_enable(bool activate)

{

[...]

if ( !keylogger_active )

{

[...]

// 13=WH_KEYBOARD_LL: Installs a hook procedure that

// monitors low-level keyboard input events. For

// more information, see the LowLevelKeyboardProc

// hook procedure.

hKeyloggerHook = SetWindowsHookExW(

13, (HOOKPROC)handle_scancode,

hSelf,

0);

if ( hKeyloggerHook )

{

keylogger_active = 1;

return 0;

}

[...]

}

After registering function handle_scancode() as a handler to

any keystroke made by the user, the following pseudo-code is executed

every time a key is pressed or released:

LRESULT handle_scancode(

int _in_nCode,

WPARAM _in_wParam,

tagKBDLLHOOKSTRUCT *_in_lParam_keystroke)

{

tagKBDLLHOOKSTRUCT *key_stroke;

WPARAM wParam;

int nCode;

int64 target;

DWORD is_keyfoo;

int is_keydown;

char tmp;

int64 key_flags;

int64 key_vk;

key_stroke = _in_lParam_keystroke;

wParam = _in_wParam;

nCode = _in_nCode;

if ( _in_nCode >= 0 )

{

target = (cfg_HotKeyMicScancode >> 8 *

(cfg_HotKeyMicScancode_len - cfg_HotKeyMicScancode_len2));

LODWORD(key_vk) = _in_lParam_keystroke->vkCode;

LODWORD(key_flags) = _in_lParam_keystroke->flags;

is_keyfoo = _in_lParam_keystroke->flags & 1;

is_keydown = ~(key_flags >> 7) & 1;

[*] send_to_dbglog(

0x1D,

L"Mic target 0x%x scancode 0x%x flags 0x%x extra 0x%x vk 0x%xn",

target,

_in_lParam_keystroke->scanCode,

key_flags,

_in_lParam_keystroke->dwExtraInfo,

key_vk);

conexant_handle_fn_keys(

cfg_MicMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

target,

&cfg_HotKeyMicScancode_len,

&cfg_HotKeyMicScancode_len2,

1);

if ( cfg_MicMuteScancodeSettings & 4 )

conexant_handle_fn_keys(

cfg_MicMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeyMicScancode2 >> 8 *

(cfg_HotKeyMicScancode2_len - cfg_HotKeyMicScancode2_len2)),

&cfg_HotKeyMicScancode2_len,

&cfg_HotKeyMicScancode2_len2,

1);

tmp = cfg_SpkMuteScancodeSettings;

if ( cfg_SpkMuteScancodeSettings & 8 && is_keyfoo

|| !(cfg_SpkMuteScancodeSettings & 8) )

{

conexant_handle_fn_keys(

cfg_SpkMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeySpkScancode >> 8 *

(cfg_HotKeySpkScancode_len - cfg_HotKeySpkScancode_len2)),

&dword_1402709C8,

&dword_1402709CC,

0);

tmp = cfg_SpkMuteScancodeSettings;

}

if ( tmp & 4 && (tmp & 8 && is_keyfoo || !(tmp & 8)) )

conexant_handle_fn_keys(

tmp,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeySpkScancode2 >> 8 *

(cfg_HotKeySpkScancode2_len - cfg_HotKeySpkScancode2_len2)),

&cfg_HotKeySpkScancode2_len,

&cfg_HotKeySpkScancode2_len2,

0);

}

return CallNextHookEx(hhk, nCode, wParam, key_stroke);

}

The function called at [*] writes every keystroke to a file or

broadcast it via Microsofts Debug Monitor APIs via store_keystroke():

void store_keystroke(LPCVOID lpBuffer)

{

WORD *scancode_logline;

int64 str_len;

DWORD NumberOfBytesWritten;

int str_newline;

scancode_logline = lpBuffer;

if ( g_write_to_logfile )

{

SetFilePointer(g_hFile, 0, 0, 2);

str_len = -1;

while ( scancode_logline[str_len++ + 1] != 0 )

;

WriteFile(

g_hFile,

scancode_logline,

2 * str_len,

&NumberOfBytesWritten,

0);

str_newline = 'n0r';

WriteFile(g_hFile, &str_newline, 4, &NumberOfBytesWritten, 0);

}

else

{

OutputDebugStringW(lpBuffer);

}

}

2023年12月17日发(作者:大令羽)

关于惠普笔记本音频驱动存在内置键盘记录器后门漏洞的安全公告

安全公告编号:CNTA-2017-0053

近期,国家信息安全漏洞共享平台(CNVD)收录了惠普笔记本音频驱动内置键盘记录器后门漏洞 (CNVD-2017-09590,对应编号CVE-2017-8360)。攻击者可利用在当前用户会话中运行的任何进程监控调试信息,记录用户通过键盘输入的任意内容,包括用户输入的密码等敏感数据,构成较为严重的信息泄露和运行安全风险。

一、漏洞情况分析

2017年4月28日,瑞士安全公司Modzero的安全研究员Thorsten Schroeder在审查WindowsActive Domain的基础设施时发现,惠普IT产品(笔记本电脑)中的Conexant音频驱动程序内置了用于调试产品的(键盘记录器),可记录用户的所有按键输入。在原出厂环境下,与Conexant音频驱动程序包被同时安装在笔记本电脑中,键盘记录功能除了处理快捷键/功能键的点击事件外,所有的键盘输入信息都会被写入所有用户权限都可读的路径中的日志文件(C:)中,甚至会传递给OutputDebugStringAPI,这使得任何可以调用MapViewOfFile API的框架或者进程都能够通过用户的键盘输入信息静默的收集敏感数据,并在白名单机制下绕过杀毒软件检测。

CNVD对漏洞的综合评级为“高危”。

二、漏洞影响范围

受漏洞影响的硬件产品型号:

HP EliteBook 820 G3 Notebook PC

HP EliteBook 828 G3 Notebook PC

HP EliteBook 840 G3 Notebook PC

HP EliteBook 848 G3 Notebook PC

HP EliteBook 850 G3 Notebook PC

HP ProBook 640 G2 Notebook PC

HP ProBook 650 G2 Notebook PC

HP ProBook 645 G2 Notebook PC

HP ProBook 655 G2 Notebook PC

HP ProBook 450 G3 Notebook PC

HP ProBook 430 G3 Notebook PC

HP ProBook 440 G3 Notebook PC

HP ProBook 446 G3 Notebook PC

HP ProBook 470 G3 Notebook PC

HP ProBook 455 G3 Notebook PC

HP EliteBook 725 G3 Notebook PC

HP EliteBook 745 G3 Notebook PC

HP EliteBook 755 G3 Notebook PC

HP EliteBook 1030 G1 Notebook PC

HP ZBook 15u G3 Mobile Workstation

HP Elite x2 1012 G1 Tablet

HP Elite x2 1012 G1 with Travel Keyboard

HP Elite x2 1012 G1 Advanced Keyboard

HP EliteBook Folio 1040 G3 Notebook PC

HP ZBook 17 G3 Mobile Workstation

HP ZBook 15 G3 Mobile Workstation

HP ZBook Studio G3 Mobile Workstation

HP EliteBook Folio G1 Notebook PC

受漏洞影响的操作系统:

Microsoft Windows 10 32

Microsoft Windows 10 64

Microsoft Windows 10 IOT Enterprise 32-Bit (x86)

Microsoft Windows 10 IOT Enterprise 64-Bit (x86)

Microsoft Windows 7 Enterprise 32 Edition

Microsoft Windows 7 Enterprise 64 Edition

Microsoft Windows 7 Home Basic 32 Edition

Microsoft Windows 7 Home Basic 64 Edition

Microsoft Windows 7 Home Premium 32 Edition

Microsoft Windows 7 Home Premium 64 Edition

Microsoft Windows 7 Professional 32 Edition

Microsoft Windows 7 Professional 64 Edition

Microsoft Windows 7 Starter 32 Edition

Microsoft Windows 7 Ultimate 32 Edition

Microsoft Windows 7 Ultimate 64 Edition

Microsoft Windows Embedded Standard 7 32

Microsoft Windows Embedded Standard 7E 32-Bit

注:其它使用了Conexant硬件和驱动器的硬件厂商也有可能受该问题影响。

三、漏洞修复建议

惠普针对该情况紧急发布过一个关闭此调试功能的修复程序。2017年5月14日,惠普又发布了更新的修复驱动程序,该程序能将所有高保真音频驱动中有此调试记录功能的源代码删除。受影响的惠普电脑对应修复程序的列表请参考惠普官网:/us-en/document/c05519670

如未能升级,可以采用如下临时解决方案:

删除MicTray可执行文件和相应的日志记录文件。仅仅删除计划任务是不能解决问题的,因为Windows服务CxMonSvc将再一次启动MicTray。删除文件位置如下:

可执行文件的位置:C:

日志文件的位置:C:

附:参考链接:

/t5/HP-newsroom-blog/Modzero-report-on-keylogger-issue/ba-p/937?from=groupmessage

/advisories/

/flaw/show/CNVD-2017-09590

int64 keylogger_enable(bool activate)

{

[...]

if ( !keylogger_active )

{

[...]

// 13=WH_KEYBOARD_LL: Installs a hook procedure that

// monitors low-level keyboard input events. For

// more information, see the LowLevelKeyboardProc

// hook procedure.

hKeyloggerHook = SetWindowsHookExW(

13, (HOOKPROC)handle_scancode,

hSelf,

0);

if ( hKeyloggerHook )

{

keylogger_active = 1;

return 0;

}

[...]

}

After registering function handle_scancode() as a handler to

any keystroke made by the user, the following pseudo-code is executed

every time a key is pressed or released:

LRESULT handle_scancode(

int _in_nCode,

WPARAM _in_wParam,

tagKBDLLHOOKSTRUCT *_in_lParam_keystroke)

{

tagKBDLLHOOKSTRUCT *key_stroke;

WPARAM wParam;

int nCode;

int64 target;

DWORD is_keyfoo;

int is_keydown;

char tmp;

int64 key_flags;

int64 key_vk;

key_stroke = _in_lParam_keystroke;

wParam = _in_wParam;

nCode = _in_nCode;

if ( _in_nCode >= 0 )

{

target = (cfg_HotKeyMicScancode >> 8 *

(cfg_HotKeyMicScancode_len - cfg_HotKeyMicScancode_len2));

LODWORD(key_vk) = _in_lParam_keystroke->vkCode;

LODWORD(key_flags) = _in_lParam_keystroke->flags;

is_keyfoo = _in_lParam_keystroke->flags & 1;

is_keydown = ~(key_flags >> 7) & 1;

[*] send_to_dbglog(

0x1D,

L"Mic target 0x%x scancode 0x%x flags 0x%x extra 0x%x vk 0x%xn",

target,

_in_lParam_keystroke->scanCode,

key_flags,

_in_lParam_keystroke->dwExtraInfo,

key_vk);

conexant_handle_fn_keys(

cfg_MicMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

target,

&cfg_HotKeyMicScancode_len,

&cfg_HotKeyMicScancode_len2,

1);

if ( cfg_MicMuteScancodeSettings & 4 )

conexant_handle_fn_keys(

cfg_MicMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeyMicScancode2 >> 8 *

(cfg_HotKeyMicScancode2_len - cfg_HotKeyMicScancode2_len2)),

&cfg_HotKeyMicScancode2_len,

&cfg_HotKeyMicScancode2_len2,

1);

tmp = cfg_SpkMuteScancodeSettings;

if ( cfg_SpkMuteScancodeSettings & 8 && is_keyfoo

|| !(cfg_SpkMuteScancodeSettings & 8) )

{

conexant_handle_fn_keys(

cfg_SpkMuteScancodeSettings,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeySpkScancode >> 8 *

(cfg_HotKeySpkScancode_len - cfg_HotKeySpkScancode_len2)),

&dword_1402709C8,

&dword_1402709CC,

0);

tmp = cfg_SpkMuteScancodeSettings;

}

if ( tmp & 4 && (tmp & 8 && is_keyfoo || !(tmp & 8)) )

conexant_handle_fn_keys(

tmp,

is_keydown,

key_stroke->scanCode,

(cfg_HotKeySpkScancode2 >> 8 *

(cfg_HotKeySpkScancode2_len - cfg_HotKeySpkScancode2_len2)),

&cfg_HotKeySpkScancode2_len,

&cfg_HotKeySpkScancode2_len2,

0);

}

return CallNextHookEx(hhk, nCode, wParam, key_stroke);

}

The function called at [*] writes every keystroke to a file or

broadcast it via Microsofts Debug Monitor APIs via store_keystroke():

void store_keystroke(LPCVOID lpBuffer)

{

WORD *scancode_logline;

int64 str_len;

DWORD NumberOfBytesWritten;

int str_newline;

scancode_logline = lpBuffer;

if ( g_write_to_logfile )

{

SetFilePointer(g_hFile, 0, 0, 2);

str_len = -1;

while ( scancode_logline[str_len++ + 1] != 0 )

;

WriteFile(

g_hFile,

scancode_logline,

2 * str_len,

&NumberOfBytesWritten,

0);

str_newline = 'n0r';

WriteFile(g_hFile, &str_newline, 4, &NumberOfBytesWritten, 0);

}

else

{

OutputDebugStringW(lpBuffer);

}

}

发布评论

评论列表 (0)

  1. 暂无评论