论坛: 编程破解 标题: 讨论一下密码框的保护方法 复制本贴地址    
作者: myjian [myjian]    论坛用户   登录
小弟近日用VB做了一个木马,本来目的是截取98至2003下程序的密码

之前都是一直PASS,但下载了一个QQ2004后才发现,无论是用HOOK还是用SendMessage方法都无法再截取到密码了

我注意到,那个**号无法用鼠标来拖黑多选,而它自己的软键盘却又可以使用.由此我想,它是不是在那个密码框的HOOK里把消息全都拦截下来了?就是说根本没有再调用CallNextHookEx了.并且只响应本进程内的SendMessage(软键盘应该就是用的这个API吧)

这个功能要是想在VB里实现,该怎么办呢?

地主 发表时间: 04-08-22 22:41

回复: jhkdiy [jhkdiy]   版主   登录
转贴:

一、非法获取Password的原理:

����Edit控件是Windows的一个标准控件,当把其Password属性设为True时,就会将输入的内容屏蔽为星号,从而达到保护的目的。虽然我们看来都是星号,但程序中的Edit控件实际仍是用户输入的密码,应用程序可以获取该控件中的密码,其他应用程序也可以通过向其发送WM_GETTEXT或EM_GETLINE消息来获取Edit控件中的内容。黑客程序正是利用Edit控件的这个特性,当发现当前探测的窗口是Edit控件并且具有ES_PASSWORD属性时,则通过SendMessage向此窗口发送WM_GETTEXT或EM_GETLINE消息,这样Edit框中的内容就一目了然了。

����二、黑客软件工作方法

����首先要取得当前的窗口,并判断是否是Edit控件,一般多通过鼠标来指定要探测的窗口,例如在WM_MOUSEMOVE消息的响应函数中进行判断,现列举代码片段如下:

//将客户坐标转换成屏幕坐标
ClientToScreen(&point);
//返回一个包含指定屏幕坐标点的窗口
CWnd* pWnd = CWnd::WindowFromPoint(point);
if (pWnd)
{
//获取窗口句柄
HWND hwndCurr = pWnd->GetSafeHwnd();
if ((::GetWindowThreadProcessId (GetSafeHwnd(), NULL)) != (::GetWindowThreadProcessId (hwndCurr, NULL)))
{
char lpClassName[255];
//获取类名
if (::GetClassName(hwndCurr, lpClassName, 255))
{
//判断是否是Edit控件
if (0 == m_strWndClass.CompareNoCase("EDIT"))
{
//获取窗口风格
LONG lStyle = ::GetWindowLong(hwndCurr, GWL_STYLE);
//如果设置了ES_PASSWORD属性
if (lStyle & ES_PASSWORD)
{
char szText[255];
//通过掌握的句柄hwndCurr向此控件发送WM_GETTEXT消息
::SendMessage(hwndCurr, WM_GETTEXT, 255, (LPARAM)szText); //密码已保存在szText中
m_strPassword = szText;
}
}
}
}
}

����上述代码中值得注意的有以下几个关键地方:
����ClientToScreen(&point);
����CWnd* pWnd = CWnd::WindowFromPoint(point);
����HWND hwndCurr = pWnd->GetSafeHwnd();

����这三句代码可以获取当前鼠标位置所在窗口的窗口句柄,在SendMessage中要用到的。
����::SendMessage(hwndCurr, WM_GETTEXT, 255, (LPARAM)szText);

����这便是真正起作用的SendMessage了,其第一个参数指定了要接收消息的窗口句柄,我们已经通过上面的代码获取到了,第二个参数就是让Edit控件返回字符的WM_GETTEXT消息了,并将得到的内容保存在szText中。
三、防范措施

����既然我们搞清除了黑客软件普遍采取的手法,那我们自然能制订出一套防范其攻击的措施来。下面我们就要对Password进行保护。
从以上分析我们可以看出:Edit控件的漏洞主要在于没有对发送WM_GETTEXT或EM_GETLINE消息者的身份进行检查,只要能找到Edit窗口句柄,任何进程都可获取其内容。所以必须要对发送消息者的身份进行验证,这里给出一种方法来验证发送消息者的身份是否合法:

����1.创建新CEdit类

����从CEdit继承一个子类CPasswordEdit,申明全局变量g_bSenderIdentity表明消息发送者的身份: BOOL g_bSenderIdentity;

����然后响应CWnd的虚函数DefWindowProc,在这个回调函数中进行身份验证:
LRESULTCPasswordEdit:efWindowProc (UINTmessage,WPARAMwParam,LPARAMlParam)
{
//对Edit的内容获取必须通过以下两个消息之一
if((message==WM_GETTEXT) ||(message==EM_GETLINE))
{
//检查是否为合法
if(!g_bSenderIdentity)
{
//非法获取,显示信息
AfxMessageBox(_T ("报告:正在试图窃取密码!"));
return 0;
}
//合法获取
g_bSenderIdentity=FALSE;
}
return CEdit:efWindowProc (message,wParam,lParam);
}

����2.在数据输入对话框中做些处理
����在对话框中申明一个类成员m_edtPassword:
����CpasswordEdit m_edtPassword;

����然后在对话框的OnInitDialog()中加入下列代码:
m_edtPassword.SubclassDlgItem(IDC_EDIT_PASSWORD,this);

����将控制与新类做关联。
����之后要在对话框的数据交换函数中将身份设为合法:
void CDlgInput:oDataExchange (CDataExchange*pDX)
{
//如果获取数据
//注意:对于CPropertyPage类这里不需要 if (pDX->m_bSaveAndValidate)条件
if(pDX->m_bSaveAndValidate)
{
g_bSenderIdentity=TRUE;
}
CDialog:oDataExchange(pDX);
//{{AFX_DATA_MAP(CDlgInput)
DDX_Text (pDX,IDC_EDIT_PASSWORD,m_sPassword);
//}}AFX_DATA_MAP
}
����这样,Password输入框就拥有了合法身份,会受到保护。

����结论:

����以上的方法仅针对VC程序,对于其他语言如VB、Delphi等语言,需要借助VC做一个Password的ActiveX控件,实现方法与上述方法基本类似。以上程序均用VisualC++6.0编制调试通过。


[此贴被 jhkdiy(jhkdiy) 在 08月22日23时42分 编辑过]

B1层 发表时间: 04-08-22 23:40

回复: ProgramLive [coolcall]   论坛用户   登录
用日志HOOK,可以的

B2层 发表时间: 04-08-23 12:08

回复: TomyChen [quest]   版主   登录
B1层,楼主已经说过了,SENDMESSAGE没用了

B3层 发表时间: 04-08-23 14:29

回复: myjian [myjian]   论坛用户   登录
B1的老大,你贴的我都差不多明白的!!

我也知道在NT内核下对外部进程的SendMessage调用会失败,但我问的问题不是怎样得到密码!

而是怎样防止别人得到我们的密码呀!!你有没有看过我发的问题呀

好了,说正题吧.现在我的意思是,QQ2004是不是在自己的Hook代码里没有再调用CallNextHookEx函数?因为我试过了,用鼠标钩子和键盘钩子都不行.全局钩子我没有试过,不过应该行,可是那样也不我想要的结果,我是想知道它用了什么办法来保护密码框的?

谢谢!

B4层 发表时间: 04-08-23 22:38

回复: ProgramLive [coolcall]   论坛用户   登录
HOOK链监视,不会做,想象中
简单的就是物理隔离

B5层 发表时间: 04-08-24 10:56

回复: myjian [myjian]   论坛用户   登录
我觉得大家有必要好好研究一下这个方法

这个方法搞清楚了,对大家都有好处的嘛.

B6层 发表时间: 04-08-24 13:23

回复: myjian [myjian]   论坛用户   登录
顶一下!!!希望大家关注!

B7层 发表时间: 04-08-25 13:03

回复: rockage [rockage]   论坛用户   登录
我也是在VB下做了个hook,是可以拦截到qq2004的键盘记录的呀,没有楼主所说的那些问题,用钩子,可行

B8层 发表时间: 04-09-06 17:51

回复: rockage [rockage]   论坛用户   登录
哦对了,我用的是全局钩子,即:
KeyboardHandle = SetWindowsHookEx( _
    WH_KEYBOARD_LL, AddressOf KeyboardCallback, _
    App.hInstance, 0&)

最后一个参数是0

B9层 发表时间: 04-09-06 17:54

回复: myjian [myjian]   论坛用户   登录
全局的键盘HOOK?

我试过了,在我机上无法截取到

不知道楼上这位朋友的具体代码是怎样的?

B10层 发表时间: 04-09-14 21:17

回复: myjian [myjian]   论坛用户   登录
还有一个问题,就是关于密码框的保护机制

可不可以在它判断"是否为外部进程的调用"上面做点手脚呢?毕竟大家都是调用API的嘛!!!

B11层 发表时间: 04-09-17 04:30

论坛: 编程破解

20CN网络安全小组版权所有
Copyright © 2000-2010 20CN Security Group. All Rights Reserved.
论坛程序编写:NetDemon

粤ICP备05087286号