0x00 写在最前
早在13年就购买了Acgart的正版授权,后来作者将acgart下架,重上了一款换皮应用Artibee,内购需要重新购买。因为作者没有完善的老用户补偿方案,遂不再付费。前段时间分手之后,时间突然多出来许多,管不住双手的我总是要找点事情做。于是乎,本着学习为主的精神,对几款福利软件动手做了破解。PS:目前单身,诚招女友
0x01 Artibee(原Acgart)
按照惯例,将可执行文件拖进ida,应用停更的比较老,没有上最新的混淆手段,比较好分析。
Artibee只发布过free版本,需要内购升级成完全版才能保存图片和看高分辨率图片,因此第一步需要破解成完全版。
根据应用使用逻辑,在点击保存按钮时,会弹出需要内购完全版页面。在字符串中查找到showPurchaseController。
查看交叉引用的方法SlideshowViewController clickSaveButton
f5一下,很清晰的看到逻辑。点击保存按钮后,依次校验/Documents/db/目录下的两个sqlite文件。sqlite文件的文件名是gtxpqmrldu和ygshvqrrgb输出的结果,长度为40位。逻辑仅校验文件是否存在,而不校验文件内容,因此可以看做是伪装成sqlite的授权文件。
观察gtxpqmrldu和ygshvqrrgb的逻辑可知,输出均为openudid的变形,
首先将40位的udid在13位/20位的位置切割,前后部分调转顺序之后拼接;
然后做字符替换操作:一个是将a替换成7,4替换成m;另一个是将9替换成f。
替换操作使用了componentsSeparatedByString和componentsJoinedByString方法,前者为按参数分割并删除分隔符,后者为连接字符串并设置参数为连接符,实际操作为替换字符串。
自行根据openudid生成相应的授权文件,既可破解Artibee的fullversion和使徒模式。
老版本的r18内容需要修改plist文件中的ispro值为true,新版经目测在init的时候检查了ispro的值,建议顺手改一下这里。plist的位置为应用对应沙盒的\Library\Preferences\work.xukeliapp.artibee.plist。
顺便一提,不知道自己设备openudid的话,可以直接在上面提到的plist中找到。
破解效果见上图,内页图过于黄暴,不予展示。
0x02 ACG Stay & CosPlay
ACG Stay 和 CosPlay是iOS上另外两款非常实用的福利软件。目前均已下架,但是可以在pp助手上下载。惯例拖进ida。
因为这两款应用是同一作者,破解思路也完全一样,因此合并在一起。
找入手点,先将设备语言更改为英文。随意收藏几张图片后,提示需要vip才可以收藏14张以上的图片。
在function中搜索vip
猜想第二个函数是右图中弹窗的构造函数
点进去验证了我的猜测,确实如此。那第一个函数就是判断是否有vip授权的函数了么?
分析收藏按钮的具体实现代码,确实是通过检测isVipUser的值来确定是否可以收藏超过14张图片。继续分析isVipUser函数。
isVipUser函数的返回值实际上是isNoAdBought的返回值,继续跟进去
isNoAdBought是检测是否内购的具体功能函数,这里通过hook把isNoAdBought的返回值改为true解决问题。有的同学可能会提问,为什么不直接修改isVipUser的返回值,而去修改isNoAdBought的返回值?当然是因为isNoAdBought比isVipUser更底层,改了底层的返回,上层自然会随之更改,而后从两者的交叉引用上也可以看得出还有更多的函数需要调用isNoAdBought的返回值。
这里改完,已经可以随意收藏图片了,不受免费用户的14张限制。但是依然不能解锁18x模式。
根据使用经验,一般福利软件是通过收藏,下载超过一定量的图片数量解锁福利功能,当然也有的是检测安装天数,启动次数等,再此不一一列举。
巧合的是,之前观察isVipUser的交叉引用,其中有一个函数calcuPoints引起了我的注意。
函数逻辑十分清晰,如果购买授权,点数=点击广告次数*8+启动次数*7+收藏图片数量*4,如果没有购买授权,则为收藏图片数*3+点击广告次数*2+启动次数*2。
当启动次数大于12次,且点数大于307时,开启福利。
为验证思路,往上跟两层,发现shouldShowHButton,很直白,也不用多说了,就是他。
将calcuPoints返回值改为true,测试ok。
HButton为调试模式开关。
0x03 独乐乐不如众乐乐
AcgStay&Cosplay解锁插件打包成了deb,越狱设备可以直接安装使用。
下载之后将后缀修改为deb即可直接安装。
Artibee如果是越狱设备直接自行创建两个sqlite文件即可。
非越狱设备可以通过尝试恢复我提供的应用数据实现破解。
附件下载完毕后将后缀改为imazingapp,并通过iMazing客户端恢复应用数据即可。
(支持iOS任意版本,包括iOS12.1.x)
iMazing为免费应用,恢复备份无需购买授权。官网https://imazing.com
0x04 写在最后
本文中所有应用均可从pp助手下载,如下架之前在App Store下载过的话也可以在App Store的已购应用中找到。ps:手冲一时爽,一直手冲一直爽。
希望2019可以成功脱单,过上没有手冲的生活。
如果本文能给您带来一些帮助,我深感荣幸。
如果不介意的话希望可以赞助一杯咖啡支持作者,您的支持是我更新的最大动力。
祝各位新的一年猪事顺利,性福美满。