设为首页 收藏本站
查看: 1818|回复: 0

[经验分享] 教你如何使用微信网页版“抓取”微信撤回消息

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2017-6-23 09:34:06 | 显示全部楼层 |阅读模式
  思路是这样的,当微信收到撤回消息的请求后,将撤回的响应包改掉,这样微信就不能撤回了,微信APP比较难搞,就直接用微信网页版抓包修改吧。
  关于微信网页版的抓包其实也比较复杂,主要是常常抓包失败,网页无法打开(支付宝、淘宝也是,貌似它们的https协议更安全,不好代理,求解),为此专门做了个vmware虚拟机,配置是xpsp3+ 搜狗浏览器6.3.8.22061+fiddler v4.6.2.32002。
DSC0000.jpg

DSC0001.jpg

DSC0002.jpg

  打开fiddler,设置https,如图:
DSC0003.jpg

  打开搜狗浏览器设置代理服务器:
DSC0004.jpg

  在浏览器里访问https://wx2.qq.com/?&lang=zh_CN,浏览器显示如下截图,表示代理成功:
DSC0005.jpg

  此时fiddler显示如下,表示抓包成功:
DSC0006.jpg

  微信手机端扫描二维码成功登陆:
DSC0007.jpg

  Fiddler截获数据包如下所示:
DSC0008.jpg

  介绍一下收到消息跟撤回消息的区别:在收到消息时,微信响应包中MsgType=1,Content是介绍到的消息:
DSC0009.jpg

  在收到撤回消息时MsgType=10002,Content是撤回的提示信息:
DSC00010.jpg

  要想查看撤回的消息,只需要将”MsgType”: 10002替换成”MsgType”: 1,并将Content 替换成友好信息就行了。
  下边编辑fiddler脚本,自动替换指定响应数据:
  要想编辑fiddler脚本,要下载一个fiddler脚本编辑插件,点击fiddler->Rules->Customize Rules, 按照提示安装插件,重启fiddler,截图如下:
DSC00011.jpg

  编辑fiddler脚本,使其在响应包中自定替换指定内容,直接编辑函数,替换如下所示:
  static functionOnBeforeResponse(oSession: Session) {
  if (m_Hide304s && oSession.responseCode== 304) {
  oSession["ui-hide"] ="true";
  }
  if(oSession.GetResponseBodyAsString().Contains('"MsgType": 10002')){
  // Remove any compression orchunking
  oSession.utilDecodeResponse();
  var oBody =System.Text.Encoding.UTF8.GetString(oSession.responseBodyBytes);
  // Replace all instances of the DIVtag with an empty string
  //var oRegEx =/<div[^>]*>(.*?)<\/div>/gi;
              //oBody = null;
              varstrBody=oBody.replace('"MsgType": 10002','"MsgType": 1');
  
              // Set the response body to thediv-less string
             //oSession.utilSetResponseBody(strBody);
              var resourse=/"Content":"(.*)"/gi;
  var resourse1='"Content":"以上为撤回消息"'; //
  varstrBody=strBody.replace(resourse,resourse1);
  //FiddlerObject.alert(strBody);
  oSession.utilSetResponseBody(strBody);
  }
  }
  保存,大功告成!!
  测试一下,先发送一段文字,然后撤回,效果如下所示:
DSC00012.jpg

  查看fiddler中的数据包,已经直接将撤回消息数据包替换掉了:
DSC00013.jpg

  这样,微信网页版一直开着,就可以查看所有被撤回的消息

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-387134-1-1.html 上篇帖子: 详解 ML2 Core Plugin(II) 下篇帖子: 如何解决虚拟机克隆导致"Bringing up interface eth0: Error: No suitable device found: no dev
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表