这篇文章也算是朝花夕拾。事实上非常早曾经就知道的原理,如今拿出来和大家交流分享一下。

故事总要有缘由。那么这个故事的缘由就是,当我曾经写了一个获取其他进程password框password的时候(前几篇博客中有描写叙述)。我抱着试一试的心情去试探了一下能不能得到 QQ 的password。当我抓到password框的句柄。然后输入给程序的时候,结果令人失望。并没有不论什么结果,也许这根本就是一个假的password框。

这便激发了我的兴趣,便有了这次探究。

QQ 的安全password框果然是下了功夫的。网上搜索相关内容,才发现。曾经腾讯用了韩国的技术来保证password的安全性,但因为涉及到驱动,造成了一部分的不稳定性,所以最后取消掉了这样的方法,那么最新的方法是怎样做到password安全呢?这样的password安全是否还有提升的空间呢?我决定试一试。

首先想到的办法便是键盘钩子,大家都知道,键盘钩子能够监听系统中全部的击键信息,立即编码实现,主要调用为:

HHOOK SetWindowsHookEx(          int idHook,
HOOKPROC lpfn,
HINSTANCE hMod,
DWORD dwThreadId
);

传入的參数是:WH_KEYBOARD

打开程序监听,目标程序选择了大家不太关注的QQMusic(手头上临时仅仅有这个程序),打开password框输入我的password,结果没有不论什么实用信息,为什么呢?我们知道假设在钩子链中前面的钩子没有显示调用后面的钩子,后面是得不到信息的,我们能不能把自己的钩子放到最前面呢。有两点须要注意。一。后安装的钩子会在钩子链的最前面。二。我们安装的是普通钩子,另一种低级的键盘钩子会在其前面运行。那我们直接安装低级钩子而且尽量迟的调用不即可了么。

程序完毕后。我发现,确实能够收到键盘信息了。只是在收到的信息中有很多干扰信息。基于纯理论分析这一做法,能够推測。肯定有一个定时发送模拟按键消息的 Timer 在运行,去掉这个 Timer,当然就没有了干扰信息。但事情进行的不是那么简单。我发现。每次我接收到的键盘消息并非我真正按下去的按键。莫非它安装了一个在我前面的钩子,改掉了按键信息?于是我便写了一个程序,去分析当前系统中的钩子的信息,结果例如以下:

0x64b012d       0xc2cbf81               QQMusic.exe
0x64b012d 0xc2cbf81 QQMusic.exe
0x64c012d 0xc2cbf81 QQMusic.exe
0x64c012d 0xc2cbf81 QQMusic.exe
0x64c012d 0xc2cbf81 QQMusic.exe
0x64d012d 0xc2cbf81 QQMusic.exe
0x64d012d 0xc2cbf81 QQMusic.exe
0x64d012d 0xc2cbf81 QQMusic.exe
0x64e012d 0xc2cbf81 QQMusic.exe
0x64e012d 0xc2cbf81 QQMusic.exe
0x64e012d 0xc2cbf81 QQMusic.exe
0x64f012d 0xc2cbf81 QQMusic.exe
0x64f012d 0xc2cbf81 QQMusic.exe
0x64f012d 0xc2cbf81 QQMusic.exe
0x650012d 0xc2cbf81 QQMusic.exe
0x650012d 0xc2cbf81 QQMusic.exe
0x650012d 0xc2cbf81 QQMusic.exe
0x651012d 0xc2cbf81 QQMusic.exe
0x651012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe
0x652012d 0xc2cbf81 QQMusic.exe

第一列便是钩子的句柄值。我是每隔一秒钟扫描一次的。能够清楚的发现,值在不断的变化。那么非常easy便能够猜想到,它肯定在不断去设置新的钩子来达到使其在钩子最前端这一效果。

那么去掉这个钩子,我们便能够使自己的钩子监听到键盘信息了。

本文仅仅给出了思路,可以看出,在password安全这一方面。还是做了不少工夫的。如今password的安全也越来越受到各个公司的重视,希望可以以此文互相交流。使我们的password安全做到更好。

揭秘QQ 安全password框的原理的更多相关文章

  1. QQ视频直播架构及原理 流畅与低延迟之间做平衡 音画如何做同步?

    QQ视频直播架构及原理 - tianyu的专栏 - CSDN博客 https://blog.csdn.net/wishfly/article/details/53035342 作者:王宇(腾讯音视频高 ...

  2. qq网吧弹框如何去掉?如何删掉NetBar文件夹?

    qq网吧弹框如何去掉?如何删掉NetBar文件夹?有些qq会弹出qq网吧,让人烦恼.而且点了那个不是网吧的反馈了多次都还会弹出.如何退出关闭删除取消去掉qq网吧呢,下面介绍一种解决方法:1.打开qq安 ...

  3. wpf实现仿qq消息提示框

    原文:wpf实现仿qq消息提示框 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/huangli321456/article/details/5052 ...

  4. 制作qq简易聊天框

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. 实现password框中显示文字提示的方式

    其实实际上实现中并不能让password中显示文字提示,但是我们在工作中有这样的需求,当没输入东西的时候,框内有提示输入密码,但是当输入东西的时候又显示的是*号,那么是如何实现的呢?其实原理很简单,就 ...

  6. 技术揭秘“QQ空间”自动转发不良信息

    大家经常会看到QQ空间自动转发一些附带链接的不良信息,即便我们的QQ密码并没有被盗取.最近通过对一个QQ空间自动转发链接进行分析,发现该自动转发机制通过利用腾讯网站存在漏洞的页面,精心构造出利用代码获 ...

  7. QQ去除聊天框广告详解——2016.9 版

    QQ聊天框广告很烦人,百度出来的一些方法早已过时,下面是博主整理出来的方法,供各位同学参考. 1.按键盘上的 Win+R 快捷键打开运行框,然后复制并粘贴 Application Data\Tence ...

  8. 揭秘井井有条的流水线(ZooKeeper 原理篇)

    本文作者:HelloGitHub-老荀 Hi,这里是 HelloGitHub 推出的 HelloZooKeeper 系列,免费开源.有趣.入门级的 ZooKeeper 教程,面向有编程基础的新手. Z ...

  9. js模态框实现原理

    <!DOCTYPE> <html> <head> <style>/* 定义模态对话框外面的覆盖层样式 */ #modal-overlay { visib ...

随机推荐

  1. SSM实战——秒杀系统之DAO层实体定义、接口设计、mybatis映射文件编写、整合Spring与Mybatis

    一:DAO实体编码 1:首先,在src目录下,新建org.myseckill.entity包,用于存放实体类: 2:实体类设计 根据前面创建的数据库表以及映射关系,创建实体类. 表一:秒杀商品表 对应 ...

  2. BIEE11G配置Oracle 12c数据源

    方法一:直接在连接池中输入连接信息 将tnsname.ora里配置的连接信息等号后面的字符串去掉空格和换行符即可) (DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)( ...

  3. 浅谈Spring的PropertyPlaceholderConfigurer

    大型项目中,我们往往会对我们的系统的配置信息进行统一管理,一般做法是将配置信息配置与一个cfg.properties的文件中,然后在我们系统初始化的时候,系统自动读取cfg.properties配置文 ...

  4. ISCSI测试

    Initiator为应用客户端,服务端Target包括设备服务器端和队列管理两部分.服务端两种共享方式:1.在服务端共享分区2.在服务端以文件方式作为共享设备共享出来 构建ISCSI网络存储 测试环境 ...

  5. iscsi共享分区测试

    要求:在服务器端Server0上创建一个分区/dev/sdb1(无需格式化),配置成iscsi target设备,块设备名称为sun1,iqn名称为iqn.2018-01.com.ultrapower ...

  6. Liability

    Liability li·a·bil·i·ty  ˌlīəˈbilədē/   noun A person or thing whose presence or behavior is likely ...

  7. linux解决“XXX is not in the sudoers file”错误

    问题:我想在我的Linux系统上使用sudo来运行一些特权命令,然而当我试图这么做时,我却得到了"[我的用户名] is not in the sudoers file. This incid ...

  8. session会话保持原理

    1. 什么是会话保持? 会话保持是负载均衡最常见的问题之一,也是一个相对比较复杂的问题.会话保持有时候又叫做粘滞会话(Sticky Sessions).会话保持是指在负载均衡器上的一种机制,可以识别客 ...

  9. Nginx 在ubuntu14.04下的安装

    来源:http://blog.csdn.net/hanshileiai/article/details/45580001 按照步骤一步一步来,绝对ok 1.如果出现错误: *4 connect() t ...

  10. SpringBoot配置属性之MVC

    SpringBoot配置属性系列 SpringBoot配置属性之MVC SpringBoot配置属性之Server SpringBoot配置属性之DataSource SpringBoot配置属性之N ...