QRLjacking

本文作者:gh0stkey

前言

某天晚上,key在研究了一下朋友圈在传的QQ点击劫持,直接导致QQ冻结24小时。然后我们一起交流着聊着聊着扯到了二维码劫持这个话题上,发现国内也没有一些实战性的文章,所以针对微信展开了二维码劫持的实战。(顺便让我安静的做个小小的标题党)

原理

首先我们来看一下QRLJacking的实际原理:

1.攻击者首先进行客户端QR会话,并将登录QR码复制到网络钓鱼网站。“现在,一个精心制作的网络钓鱼页面有一个有效和定期更新的QR码可以被发送给受害者。”

2.攻击者将钓鱼页面发送给受害者。

3.受害者使用特定目标移动应用扫描QR码。

4.攻击者获得受害者帐户的控制权。

5.该服务正在与攻击者的会话交换所有受害者的数据。

这个原理的缺陷在于 -> 攻击者需要打开客户端QR会话,所以就只能进行1V1的实时性攻击,缺陷较大。

而我们实验室的成员在交流的时候发现其实可以实时撒网式QRLJacking(命名为:Netting-QRLJacking),恰好之前研究过微信的WEB协议,所以这里拿微信来当作“实验靶机“。

Netting-QRLJacking的原理如下:

1.攻击者首先精心制作一个网络钓鱼页面,钓鱼页面获取真实页面的二维码。

2.攻击者将钓鱼页面发送给受害者。

3.受害者使用特定目标移动应用扫描QR码。

4.攻击者后台获得受害者帐户的认证链接。

5.攻击者打开认证链接后直接控制受害者的微信权限。

协议分析

因为写过微信机器人,所以第一时间想起了wxpy这个神奇的模块,不过很有意思的写第一条命令的时候就遇到挫折:

from wxpy import *

bot = Bot()

Bot()需要执行完之后才会执行下一条代码,但是我用的Flask框架的代码就无法执行。

那怎么办?只能自己去分析微信QR快速登陆的WEB协议:

1. 获取uuid

(这个uuid是一个很关键的东西,我们可以通过接口去获取)

接口:

https://login.weixin.qq.com/jslogin

POST正文:

appid=wx782c26e4c19acffb&fun=new&lang=zh_CN

返回结果:

2. 获取的uuid与链接https://login.weixin.qq.com/qrcode/组合->https://login.weixin.qq.com/qrcode/ob8jLaxD6Q==

返回结果:

aHR0cHM6Ly9sb2dpbi53ZWl4aW4ucXEuY29tL2wvb2I4akxheEQ2UT09 (二维码自动识别)

(这就是二维码的地址)

3. 监听接口https://login.wx.qq.com/cgi-bin/mmwebwx-bin/login?loginicon=true&uuid=uuid&tip=1&r=855749254&_=1502382803479

GET请求参数中的uuid也就是上面的uuid,正常组合就行。

这个监听接口打开,只要有人扫描2的二维码那么就会返回消息:

这个返回的其实就是微信头像而已:

真的只是头像而已么?有心的人已经注意到了最开始有一个window.code=201,这个window.code=201是扫描成功后会返回的,而如果二维码时效性过期就会返回window.code=400。

window.userAvatar是头像,window.redirect_uri是用户凭证链接(这里只要我们点开链接直接可以进入用户微信WEB界面进行任意操作)

代码编写

这里使用一个能够快速开发flask的框架来完成

首先定义一个index的route当用户访问index时调用获取uuid的接口 将其渲染到模板中

模板获取后端传过来的uuid 并用img标签去调用获取二维码的接口

在客户端上显示出来 紧接着轮询二维码扫描的API

并且判断各种情况 尽可能实现地和微信一样

前端轮询代码

二维码扫描的route:

前端用ajax请求后端 将返回的结果转换为Javascript表达式

当全局里面的code为408的时候说明没有扫描

继续递归调用当前函数

当全局里面的code为400的时候说明二维码过期了

自动刷新当前界面获取新的二维码

当全局里面的code为201的时候说明扫描成功了

但没有在移动终端点击确认 将返回的用户头像渲染到界面中 继续递归调用当前函数

当全局里面的code为200的时候说明用户在移动终端点击确认了

这时候将返回的redirect_uri传入到后端 接着跳转返回的redirect_uri

扫描成功时调用的route:

钓鱼实践

You died.戏剧性的是这里key自己日了自己了,奶权并没有上当~

研究人员gh0stkey 来自米斯特安全攻防实验室@ 奶权 & vulkey

参考资料:

https://www.owasp.org/index.php/Qrljacking

http://wxpy.readthedocs.io

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,068评论 4 62
  • 序 本文主要来研究一下二维码登录的相关场景和原理。 场景 主要的场景有如下几个: app扫二维码登录pc版系统比如...
    go4it阅读 787评论 0 5
  • 不要去反复思考同一个问题,不要把所有的感情都放在一个人身上,你还有父母,有朋友。
    一禅_578b阅读 173评论 0 0
  • “龟孙子,三个打一个有意思吗?有种单挑!” 原本宁静的巷子里,突然多了争吵声,那清脆像药一般的声音充斥着整条小巷。...
    郁寒阅读 466评论 0 0
  • 生命 在飞逝的铁轨下 被碾去它烧灼的心脏 生命遁入鬼门 如一滴水 坠入水中 是失神时列车的歌喉使他惊惧...
    非洲美眉阅读 167评论 0 0