开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1046|回复: 14
收起左侧

[技术专题] yd云手机登录算法分析

[复制链接]
结帖率:75% (21/28)
发表于 2024-8-24 21:51:59 | 显示全部楼层 |阅读模式   山东省济宁市
在这篇文章中,我们将详细解析yd云手机的登录算法,涵盖从抓包到定位加密入口、再到分析加密算法的每一步,最后通过Python实现整个加密过程。

第一步:抓包-登录
0.png

在抓包过程中,捕获到了请求,需重点关注的是 code 和 mobile 的加密算法。

第二步:定位加密入口



0-2.png

通过搜索code 和 mobile,发现结果较多,改为直接

搜索URL请求中的关键字:login/validateCode。


1.png


这里搜索结果就2个,发现第二个是一个post请求,进去看看

2.png


第三步:分析加密算法

看到在g方法中,看到熟悉的mobile和code。我们可以看到mobile 和 code通过 c["a"].getRsaCode 方法进行处理,从方法名字可以看出这是应该是一个RSA加密,我们在这里下断点进行调试。

2-1.png

已经断了下来,我们继续跟进

3.png

[JavaScript] 纯文本查看 复制代码
            getRsaCode: function(e, n) {
                n = n || u["a"].decryptedKey(s["a"].encryptPubKey);      
                var t = new window.JSEncrypt;
                t.setPublicKey(n);
                var o = t.encrypt(e.toString());
                return o
            }


从这里我们可以看出,getRsaCode方法就是加密的核心流程,现在让我们逐行分析一下这个方法的加密流程:

[JavaScript] 纯文本查看 复制代码
 1.首先检查是否传入了 n,如果没有传入,则使用 u["a"].decryptedKey(s["a"].encryptPubKey) 计算出一个默认的公钥。
 2.创建了一个新的 JSEncrypt 对象实例 t。JSEncrypt 是一个广泛用于浏览器端的 RSA 加密库,提供 RSA 加密和解密的功能。
 3.使用 t.setPublicKey(n) 将刚才获取的公钥 n 设置为加密时使用的公钥。
 4.t.encrypt(e.toString()) 使用 RSA 加密算法对参数 e 进行加密,并将结果存储在变量 o 中。
 5.返回加密后的字符串 o。


我们了解了具体的加密流程,下一步应该是找出加密的公钥。
继续跟进decryptedKey这个方法分析:


4.png

发现Y 函数被赋值给了 u["a"] 对象的 decryptedKey 属性,现在可以这样理解,decryptedKey方法就是y方法。
我们现在具体分析Y方法:

[JavaScript] 纯文本查看 复制代码
           function Y(e) {
            var n = e
              , t = atob(n)
              , o = t.match(/[\s\S]{1,8}/g)
              , c = o.map((function(e) {
                return e.split("").reverse().join("")
            }
            ))
              , i = c.join("");
            return i
        }

[JavaScript] 纯文本查看 复制代码
>  - 将传入的参数 e 赋值给局部变量 n。
>  
> - t = atob(n):使用 JavaScript 内置的 atob 函数对变量 n 进行解码,并将解码后的结果存储在 t 变量中。
>  
> - o = t.match(/[\s\S]{1,8}/g):将解码后的字符串 t 按照每 1 到 8 个字符分割,并返回一个数组 o。
> 
>- c = o.map((function(e) { return e.split("").reverse().join("") })):对数组 o 中的每个元素(即每个子字符串)进行处理,将每个子字符串的字符顺序反转,并返回一个新的数组 c。
> 
> - i = c.join(""):将数组 c 中的所有反转后的子字符串拼接成一个完整的字符串 i 并返回。


目前,还差一个s["a"].encryptPubKey的值,这个值就是 y方法中传入的参数e,也就是一个包含了加密公钥信息的值    我直接Ctrl+f搜索 encryptPubKey

5-1.png

5.png

到了这里,整个加密流程已经分析完毕。我们来总结一下整体流程:

[JavaScript] 纯文本查看 复制代码
 1.调用 getRsaCode 进行加密
 2.公钥的处理、
 3.解码并生成公钥
 4.RSA 加密



第四步:算法实现
下面通过python实现的算法结果:
8.png

[Python] 纯文本查看 复制代码
加密结果: TZCBUcncDjPouTx4awy01J3T3yETfU9b6NcNI24R5+eMTzYX7sM08wAJnqQz31htBYkmpPuN5ZrZ2zlcLZvS3sTyH33cGg4IMkfvULoKUq0lYiZz/jUpTlH9dyxu05DH1fUHEnYMoBdyuzPql4WVSyD25zecVTfkiGdF2bRERvhqCbfkEDe+5yqnhF4vZoxVZUiOW+HVMYOVxDsHJmjvAvqAEAkF37w2jvqLejr5KIgxOjlLCAyrX2iyYcMwSPYOhoK3YyfjoWtFhmL+/ft8/Pd6Z7g0PAvoRZS2pqL1nV9vuzpFDQahvMLtcuCXq53JfDa8iRWkSc5ETPHZoT1+kA==



[color=rgba(0, 0, 0, 0.75)]

这就是完整的分析过程,通过详细的步骤,我们深入理解并实现了该yd云手机登录算法的加密机制。希望对你有所帮助


[color=rgba(0, 0, 0, 0.75)]

感谢阅读本文,如有疑问或建议,请在评论区留言!



0-1.png

结帖率:67% (2/3)
发表于 2024-9-9 09:53:40 | 显示全部楼层   山东省济南市
看一下 学习学习
回复 支持 反对

使用道具 举报

发表于 2024-9-2 23:55:59 | 显示全部楼层   广西壮族自治区柳州市
学习学习
回复 支持 反对

使用道具 举报

结帖率:74% (25/34)

签到天数: 18 天

发表于 2024-9-2 20:07:44 | 显示全部楼层   陕西省西安市
11111111111111111111111
回复 支持 反对

使用道具 举报

签到天数: 1 天

发表于 2024-9-1 16:56:23 | 显示全部楼层   河南省信阳市
KKKKKKKKKKKK
回复 支持 反对

使用道具 举报

签到天数: 7 天

发表于 2024-8-28 18:47:26 | 显示全部楼层   江苏省无锡市
666666666666666666666
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 11 天

发表于 2024-8-25 20:34:39 高大上手机用户 | 显示全部楼层   湖北省天门市
学习一下
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)

签到天数: 18 天

发表于 2024-8-24 23:53:42 | 显示全部楼层   河北省邯郸市
6666666666666666666666
回复 支持 反对

使用道具 举报

签到天数: 15 天

发表于 2024-8-24 23:32:38 | 显示全部楼层   广东省东莞市
谢谢分享
回复 支持 反对

使用道具 举报

发表于 2024-8-24 23:29:40 | 显示全部楼层   辽宁省沈阳市
好好好好好好
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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