shell 重签 IPA 包

简介

最近有 ipa 包的重签需求,在此记录一下

shell 脚本

#重签路径
sign_path=$1

#需要重签的 ipa 路径
ipa=$2

cd $sign_path

#替换 pp 文件名
provisioningProfile='xxxxx.mobileprovision'

#替换 team id
distributionCertificate='iPhone Distribution:  XXXXX'

#替换 bundleid
bundleIdentifier="com.xxxx.xxxx"

echo "解压缩 ipa  ********** "

unzip -q "$ipa"

cd Payload
declare -a appsInPayload=()
appsInPayload=$(find . -name '*app' | sed 's|^\./||')
cd ..
if [[ ${#appsInPayload[*]} -gt 1 ]]; then
  echo "Payload 中不止包含 1 个.app 文件 **********/ (${appsInPayload[*]})"
  echo -e "重签失败 **********"
  exit 1
fi
app=$appsInPayload

echo -e"删除原有的 _CodeSignature**********"
rm -r -f Payload/"$app"/_CodeSignature

echo -e"解密 pp 文件**********"
security cms -D -i "$provisioningProfile" > ProvisioningProfile.plist 2>&1

/usr/libexec/PlistBuddy -x -c 'Print Entitlements' ProvisioningProfile.plist > Entitlements.plist 2>&1

echo -e"将新的 pp 文件拷贝到 app 中 ********** "
cp "$provisioningProfile" Payload/"$app"/embedded.mobileprovision
if [[ -n $bundleIdentifier ]]; then
  /usr/libexec/PlistBuddy -x -c "Set :CFBundleIdentifier $bundleIdentifier" Payload/"$app"/Info.plist
else
    echo ""
fi

echo -e"重签所有的动态库 **********"

if [[ -e Payload/$app/Frameworks ]]; then
  cd Payload/"$app"/Frameworks
  swiftLibraries=$(find . -name '*dylib')
  SDK_PATH="/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/lib/swift/iphoneos/"
  for dylib in $swiftLibraries; do
    codesign -f -s "$distributionCertificate" "$dylib"
  done
  frameworks=$(find . -name '*framework')
  for framework in $frameworks; do
    codesign -f -s "$distributionCertificate" "$framework"
  done
  cd ../../..
fi

codesign -f -s "$distributionCertificate" --entitlements Entitlements.plist Payload/"$app"

echo "重新生成 ipa 文件 **********"
zip -q -r resigh.ipa Payload SwiftSupport Symbols

echo -e "重签完成 **********"
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 重签名的三种方式 手动重签 \ xcode重签 \ shell脚本重签名 以微信越狱版举例 手动重签查看描述文件...
    星辰流转轮回阅读 631评论 0 0
  • 前言: 玩逆向的目的 ?为了应用安全 , 我们首先要知道 Hackers 都是怎么做的 , 他们如何做到可以调试我...
    lb_阅读 3,225评论 2 4
  • 1、简介 利用Xcode的命令 security 和 codesign 重签ipa文件。重签名与Xcode里用bu...
    iHTCboy阅读 2,196评论 0 3
  • 为啥要做反编译 之前在进行项目时,经常性的会出现plist内某个参数有错,或者资源出错,亦或者script脚本有问...
    夏小豆阅读 3,868评论 0 2
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,624评论 28 53