iOS 应用混淆(Swift)

当前例子是为了演示swift语言开发的应用的混淆,其他语言暂不适用。

要运行本示例的要求

  • 安装了Cocos Pods(你工程用到了才用装)
  • 安装了 homebrew
  • 安装了 Python 3.x 版本
  • 安装了Xcode 14.x 以上
  • MacOS 10.0以上系统
  • 安装了crab-orange.app
  • 已经取得了注册码

索要免费体验版授权码

请先准备一个新账号,并且创建一个应用,然后提供提供一下 bundle id

邮箱:759610734@qq.com (如果2日内未回复,请加QQ:759610734)

创建工程

  1. 解压Products.zip,一般都会包含三个文件后缀分别是 .listenkey.dat.framework

  2. 在工程目录 ~/Desktop/WNXHuntForCity 下 建立一个COSDK目录,把我们给您的Products/COSDK.frameworkProducts/**.dat拖动进去

  3. 然后执行终端命令 cd ~/Desktop/WNXHuntForCity下,执行 pod install --no-repo-update (用了cocospods的,请执行一次)

  4. xcode打开 ~/Desktop/WNXHuntForCity.xcworkspace 文件,把COSDK目录加入到工程里面 (实际的COSDK.framework名称跟图片可能不一致)

  5. 修改一下WNXHuntForCity.xcprojectbundle id 改为我们给了您注册文件的那个 bundle id

  6. 编译一次项目,确保能正确编译

混淆器配置

  1. 打开crab-orange.app

  2. 点击【注册码】按钮,导入我们给你的一个Products.zip里面*.listenkey文件

  3. 点击"新建项目"按钮,按照引导的选择对应的~/Desktop/WNXHuntForCity/WNXHuntForCity.xcworkspace文件,选对应的注册码,然后选主应用的target选主应用的名字,比如WNXHuntForCity,点击完成后创建项目成功

  4. 点击当前项目的最右边一个按钮,进入WNXHuntForCity 这个项目,等待完成工程分析(项目结构都能在界面中正确显示了)

    Warning

    如果你的项目使用了cocospod,请先执行 pod update 或者 ‘pod install` 然后再来做工程分析,并且确保你的工程可以正常编译

  5. 退出当前项目,回到工程列表(关闭当前项目就行了),找到工程设置按钮点进去

  6. 第一个选项卡是"依赖文件",找到COSDK那个分组,点 '+' 按钮,依次把~/WNXHuntForCity/WNXHuntForCity/COSDK里面3个文件加入进去

  7. 进入【编译设置】选项卡,添加一个Debug证书设置,target选择WNXHuntForCitybundle id使用您新应用的bundle id(注意一定要正确,不然会影响查找本地 mobile provision file文件错误),certificate 选正确的证书,然后点 mobile provision file 旁边的搜索按钮,可以从本地识别对应的文件)

    Warning

    1.使用了 XcodeSigning & Capabilities 里的Automatically manage signing 使用账号自动签名的记得关闭,不然会引起编译错误。2.使用了 XcodeSigning & Capabilities 里的 xcode sign in with Apple,但是你的mobileprofile里面没有打开支持的,在编译阶段会报错,请删除掉。3.混淆程序执行后,在编译阶段失败后,可以通过打开Xcode工程,查看签名设置,如果发现不对,可以修改混淆程序中的配置,在点击【开始混淆】(切勿直接修改Xcode工程,避免导致需要点击重置按钮重新开始)

  8. 点击【开始混淆】按钮,会弹出运行设置,默认【调试模式】是打开的

  9. 打开【COSDK自动初始化】,就能省略在main函数里面加入NSCOSDKInit() 的部分,因为 swift 也找不到main函数定义

  10. 修改【COSDK自定义名称】为给你的Products.zip里面的那个framework的名字(如果是COSDK,可以不填写)

  11. 打开【swift混编】,避免提示找不到一些swift库

  12. 确保关闭 【COSDK使用动态库】,如果你用了Podfile,打开了 use_frameworks!,就需要对应打开这个

  13. 在架构里面,只打开ARM64 就可以了,然后点击【开始混淆】

  14. 再次点击【开始混淆】按钮,然后一直等到混淆器提示混淆完成,点击【打开工程】按钮,准备运行应用,会发现 WNXHuntForCity 那个下拉框打开后,会多一个target,它的icon上面有一个阻止的标示,选中它,会自动安装应用到手机,就可以开始调试了

    Tip

    如果你的手机不是arm64架构的,想调试的时候新版本的Xcode是会提示无法安装的,请更换一个arm64架构的手机调试(安装不影响)