重签名,马甲包环境配置iOS集合

iOS软件包ipa重签名详解

2018-07-23  本文已影响0人  昵称你也抢我的

ipa是iOS系统app安装包,如果我们想对App Store上的软件进行修改然后重新安装到手机上、或者对已有的APP进行企业分发而不更改包名、或者手机上安装多个相同的APP等都需要进行重签名。

本文主要讲解重签名,不涉及砸壳,如ipa包是在App Store下载的,则需要先进行砸壳。

准备工作

使用软件工具进行重签名(需要更改包名Bundle Id)

iReSign

下载地址iReSign,使用反法非常简单:

image

点击重签名就可以在原ipa文件同一目录生成以resigned.ipa结尾新的重签名的ipa文件。

ios-app-signer

下载地址https://github.com/DanTheMan827/ios-app-signer
这个项目是在iReSign基础上开发的,自己使用Xcode编译即可。

image
使用也是非常简单:
选择需要重签名的包,签名用的证书,描述文件,包名,点击Start即可。后三项根据自己的需求选填,亲测修改名称无效。

使用codesign命令进行签名(无需修改包名 Bundle Id)

生成 entitlements.plist 文件

我们有两种方式获得entitlements.plist文件

  1. 使用iReSign对进行重签名,然后将重签名后的包进行解压,得到entitlements.plist文件
  2. 通过mobileprovision文件生成:
    首先生成一个完整的plist文件
security cms -D -i embedded.mobileprovision > embedded.plist

image
我们实际上需要的是中间红线框的那部分,接下来执行
/usr/libexec/PlistBuddy -x -c 'Print:Entitlements'  embedded.plist > entitlements.plist

就可以生成我们需要的entitlements.plist了。

重签名

一切准备就绪,接下来开始进行签名操作了

  1. 解压ipa包
unzip xxx.ipa

tip:xxx.ipa为你的需要重签名的包。

  1. 删除签名文件
rm -rf Payload/xxx.app/_CodeSignature/
  1. 替换配置文件
cp embedded.mobileprovision Payload/xxx.app/
  1. 签名
codesign -f -s "你的证书的名称" --entitlements entitlements.plist Payload/xxx.app

tip:证书的名称你可以通过mac自带的keychain Access钥匙串访问程序查看电脑上的证书。

  1. 打包
zip -r resign_xxx.ipa Payload/

tip:resign_xxx.ipa名字是随便起的。

大功告成,你可以顺手解压出来的文件清理删除掉rm -r Payload

上一篇下一篇

猜你喜欢

热点阅读