上一题下一题
跳转到
 
 
  世界如此多姿,发展如此迅速,窥一斑未必还能知全豹。但正如万花筒一样,每一个管窥都色彩斑斓。  
 
 
  知识通道 | 学习首页 | 教师首页 | PK首页 | 知识创造首页 | 企业首页 | 登录
 
本文对应知识领域
如何在VB中实现密码的读取
作者:北京 彭波 申领版权
2010年11月14日 共有 876 次访问 【添加到收藏夹】 【我要附加题目
受欢迎度:

    前段时间在网上流行一个能从用“*”加密的文本框中读取密码的软件,本人也曾很好奇它是如何实现密码的读取。经过一段时间的探索,终于弄清楚其基本的原理,下面就让我们用VB来实现。
    
    首先,建立一个标准EXE工程,窗体名称为Mainfrm,并将ScaleMode设为3-Pixel。在窗体上放置四个Label控件和四个名称依次为PointText、hWndText、WndClassText和PasswordText的TextBox控件,再放置一个名称为Check1,Caption属性为 “总在最上面”的CheckBox控件和一个名称为Picture1的PictureBox控件。整个窗口的布局如图所示。为了程序外观的美化,在Picture1中放置一幅合适的图片,并制作一个相应的光标,将光标文件命名为Cursor1.cur并存在源程序所在的目录下。

    
     其次,新建一个类模块,在其中输入如下内容:
    
    Option Explicit
    
    Declare Function SetWindowPos& Lib“user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long)
    
    Declare Function SetCapture Lib “user32" (ByVal hwnd As Long) As Long Declare Function ReleaseCapture Lib “user32" () As Long
    
    Declare Function ClientToScreen Lib “user32" (ByVal hwnd As Long, lpPoint As POINTAPI) As Long Declare Function WindowFromPoint Lib “user32" (ByVal xPoint As Long, ByVal yPoint As Long) As Long Declare Function GetClassName Lib “user32" Alias “GetClassNameA" (ByVal hwnd As Long, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long Declare Function GetLastError Lib “kernel32" () As Long Declare Function SendMessage Lib “user32" Alias “SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As String) As Long
    
    Public Const WM_GETTEXT = &HD
    
    Type POINTAPI
    
    x As Long
    
    y As Long
    
    End Type
    
    注意函数SendMessage的声明中最后一个变量并不是如API浏览器所提供的lParam As Any,而是ByVal lParam As String或Byval lParam As Any,否则你的程序会毫无疑问地崩溃。
    
    最后,键入主程序原代码如下:
    
    Dim IsDragging As Boolean '是否处在拖动读取状态
    
    Private Sub SetOnTop(ByVal IsOnTop As Integer)
    
    Dim rtn As Long
    
    If IsOnTop = 1 Then
    
    rtn = SetWindowPos(Mainfrm.hwnd, -1, 0, 0, 0, 0, 3) '将窗口置于最上面
    
    Else
    
    rtn = SetWindowPos(Mainfrm.hwnd, -2, 0, 0, 0, 0, 3)
    
    End If
    
    End Sub
    
    Private Sub Check1_Click()
    
    SetOnTop (Check1.Value)
    
    End Sub
    
    Private Sub Form_Load()
    
    Check1.Value = 1
    
    SetOnTop (Check1.Value)
    
    IsDragging = False
    
    End Sub
    
    Private Sub Form_MouseMove(Button As Integer, Shift As Integer, x As Single, y As Single)
    
    If IsDragging = True Then
    
    Dim rtn As Long, curwnd As Long
    
    Dim tempstr As String
    
    Dim strlong As Long
    
    Dim point As POINTAPI
    
    point.x = x
    
    point.y = y
    
    '将客户坐标转化为屏幕坐标并显示在PointText文本框中
    
    If ClientToScreen(Mainfrm.hwnd, point) = 0 Then Exit Sub
    
    PointText.Text = Str(point.x) + “," + Str(point.y)
    
    '获得鼠标所在的窗口句柄并显示在hwndtext文本框中
    
    curwnd = WindowFromPoint(point.x, point.y)
    
    hwndtext.Text = Str(curwnd)
    
    '获得该窗口的类型并显示在WndClassText文本框中
    
    tempstr = Space(255)
    
    strlong = Len(tempstr)
    
    rtn = GetClassName(curwnd, tempstr, strlong)
    
    If rtn = 0 Then Exit Sub
    
    tempstr = Trim(tempstr)
    
    WndClassText.Text = tempstr
    
    '向该窗口发送一个WM_GETTEXT消息,以获得该窗口的文本,并显示在PasswordText文本框中
    
    tempstr = Space(255)
    
    strlong = Len(tempstr)
    
    rtn = Send Message(curwnd, WM _GETTEXT, strlong, tempstr)
    
    tempstr = Trim(tempstr)
    
    PasswordText.Text = tempstr
    
    End If
    
    End Sub
    
    Private Sub Form_MouseUp(Button As Integer, Shift As Integer, x As Single, y As Single)
    
    If IsDragging = True Then
    
    Screen.MousePointer = vbStandard
    
    IsDragging = False
    
    '释放鼠标消息的抓取
    
    ReleaseCapture
    
    End If
    
    End Sub
    
    Private Sub Picture1_MouseDown(Button As Integer, Shift As Integer, x As Single, y As Single)
    
    If IsDragging = False Then
    
    IsDragging = True
    
    Screen.MouseIcon = LoadPicture(App.Path + “\Cursor1.cur")
    
    Screen.MousePointer = vbCustom
    
    '将以后的鼠标输入消息都发送到本程序窗口
    
    SetCapture (Mainfrm.hwnd)
    
    End If
    
    End Sub

    
     要说明一点的是,本文的目的并不是告诉各位读者如何去偷取密码,而是要向各位阐明,要获得那些用*号隐藏的密码是多么的容易,从而提高各位安全的意识。相信看了本文以后,你不会再随随便便选择“保存密码”选项了吧。
    
    本程序在Window98SE+VB5.0中运行通过。

    

 

相关新闻

您可能对这些感兴趣  

用VB做定时断线程序
VisualBasic中的界面设计原则和编程技巧
VB6.0与Windows API 间的呼叫技巧
制作可以自动隐藏的弹出式菜单
ListBox中的字符串超长显示的解决方法
VB中的Unicode 和 Ansi 格式
优化程序显示速度
Visual Basic 产生渐层的 Form 背景
用VB实现客户——服务器(TCP/IP)
用VB制作注册软件的方法

题目筛选器
日期:
类型:
状态:
得分: <=
分类:
作者:
职业:
关键字:
搜索

 
 
 
  焦点事件
 
  知识体系
 
  职业列表
 
 
  最热文章
 
 
  最多引用文章
 
 
  最新文章
 
 
 
 
网站介绍 | 广告服务 | 招聘信息 | 保护隐私权 | 免责条款 | 法律顾问 | 意见反馈
版权所有 不得转载
沪ICP备 10203777 号 联系电话:021-54428255
  帮助提示    
《我的太学》是一种全新的应用,您在操作中遇到疑问或者问题,请拨打电话13564659895,15921448526。
《我的太学》