iOS重打包之脚本替换

上一篇文章讲的是通过MonkeyDev工具重打包,其实MonkeyDev的功能远不止用来重打包,他可以很方便的注入自己的动态库、调试指令,后面我还会介绍。

今天这篇文章讲一下另一种重打包的方法,脚本打包。

我们要知道重打包的关键点是在如何对现有app重签名,除了Product - Archive打包,其实在Debug运行代码的时候也需要对IPA进行签名的。那试想一下,我们是不是可以在给自己工程签名的时候,把我要重打包的app替换自己工程的app,这样工程在签名的时候是不是实际上给替换的工程签名,这样就能运行到手机上了。

一、签名在哪

首先,我们对一个工程进行编译,会在product文件夹下生成.app的文件

然后Show in Finder,右击 - 显示包内容,如图

_CodeSignature里面是对当前app中所有文件进行的签名记录,使用hash算法。
embedded.mobileprovision文件是开发证书,需要在设置中授权的,之前讲过,可以看下这里。

二、新建工程

接下来,新建一个空工程,什么都不要做,直接运行到手机上,可以把此工程想象为一个壳。

三、添加脚本

工程目录下,新建appSign.sh脚本文件,文件内容写好了,直接使用就行,

# ${SRCROOT} 它是工程文件所在的目录
TEMP_PATH="${SRCROOT}/Temp"
#资源文件夹,我们提前在工程目录下新建一个APP文件夹,里面放ipa包
ASSETS_PATH="${SRCROOT}/APP"
#目标ipa包路径
TARGET_IPA_PATH="${ASSETS_PATH}/*.ipa"
#清空Temp文件夹
rm -rf "${SRCROOT}/Temp"
mkdir -p "${SRCROOT}/Temp"#----------------------------------------
# 1. 解压IPA到Temp下
unzip -oqq "$TARGET_IPA_PATH" -d "$TEMP_PATH"
# 拿到解压的临时的APP的路径
TEMP_APP_PATH=$(set -- "$TEMP_PATH/Payload/"*.app;echo "$1")
# echo "路径是:$TEMP_APP_PATH"#----------------------------------------
# 2. 将解压出来的.app拷贝进入工程下
# BUILT_PRODUCTS_DIR 工程生成的APP包的路径
# TARGET_NAME target名称
TARGET_APP_PATH="$BUILT_PRODUCTS_DIR/$TARGET_NAME.app"
echo "app路径:$TARGET_APP_PATH"rm -rf "$TARGET_APP_PATH"
mkdir -p "$TARGET_APP_PATH"
cp -rf "$TEMP_APP_PATH/" "$TARGET_APP_PATH"#----------------------------------------
# 3. 删除extension和WatchAPP.个人证书没法签名Extention
rm -rf "$TARGET_APP_PATH/PlugIns"
rm -rf "$TARGET_APP_PATH/Watch"#----------------------------------------
# 4. 更新info.plist文件 CFBundleIdentifier
#  设置:"Set : KEY Value" "目标文件路径"
/usr/libexec/PlistBuddy -c "Set :CFBundleIdentifier $PRODUCT_BUNDLE_IDENTIFIER" "$TARGET_APP_PATH/Info.plist"#----------------------------------------
# 5. 给MachO文件上执行权限
# 拿到MachO文件的路径
APP_BINARY=`plutil -convert xml1 -o - $TARGET_APP_PATH/Info.plist|grep -A1 Exec|tail -n1|cut -f2 -d\>|cut -f1 -d\<`
#上可执行权限
chmod +x "$TARGET_APP_PATH/$APP_BINARY"#----------------------------------------
# 6. 重签名第三方 FrameWorks
TARGET_APP_FRAMEWORKS_PATH="$TARGET_APP_PATH/Frameworks"
if [ -d "$TARGET_APP_FRAMEWORKS_PATH" ];
then
for FRAMEWORK in "$TARGET_APP_FRAMEWORKS_PATH/"*
do#签名
/usr/bin/codesign --force --sign "$EXPANDED_CODE_SIGN_IDENTITY" "$FRAMEWORK"
done
fi#注入
yololib "$TARGET_APP_PATH/$APP_BINARY" "Frameworks/BundleHook.framework/BundleHook"

里面的每一步都写了注释,其实就是我们替换掉工程中的.app文件,执行签名。

还需要在工程目录下新建APP文件夹,将我们要重打包的ipa(也就是脱壳出来的)放入,还不会脱壳的可以看下之前的脱壳文章iOS完美脱壳。

三、配置工程

Build Phases - Run Script(没有自己新建一个就行)
Shell : /bin/sh

${SRCROOT}/appSign.sh


此目的就是在运行时,执行此脚本。

四、运行程序

直接运行工程,重点:前提一定要先运行下空工程,再配置,最后再运行
此时我们可以看到把脱壳出来的ipa,使用我们自己的签名运行到了手机上。

五、后续

我们知道了两种方式去重打包app,但是我们的目的还是通过重打包,将我们自己的代码注入到app内,达到Hook效果。
另一种方式的重打包
《iOS重打包之MonkeyDev》

下一篇文章重打包后注入动态库,做OC方法的HOOK。
《iOS重打包并注入动态库HOOK OC函数》

iOS重打包之脚本替换相关推荐

  1. ios重签名shell脚本_03:双层签名和重签名流程以及shell脚本重签名

    复习 1:双向签名7不流程 2:查看签名信息和证书信息 3:查看用户权限 4:shell脚本签名 目录 1:双向签名7不流程 2:查看签名信息和证书信息 3:查看用户权限 4:shell脚本签名 正文 ...

  2. ios重签名shell脚本_iOS逆向——shell重签名及代码注入

    感谢hank老师 上一章我们讲了应用签名原理和重签名原理,不再赘述,没有看过的同学可以点这里-- 这章概述shell脚本重签名.可能有的同学认为有很多工具都能快速的帮助我们重签名实现需求,但我更希望在 ...

  3. ios重签名shell脚本_IOS应用重签名(三种方法)

    终端命令(相关的一些指令) •$security find-identity -v -p codesigning列出钥匙串里可签名的证书 •$Codesign–fs"证书串"文件名 ...

  4. 记一次ios重打包签名的过程

    1 创建一个工作目录,比如桌面上的resign目录,其绝对路径是/Users/apple/desktop/resign/,并切换到当前目录下 2 解压缩需要重签名的cma.ipa到payload目录 ...

  5. iOS自动化打包之重签名导出不同证书ipa探索

    在完成基础的自动包打包流程过后, 随即也出现了日常中常见的问题, 比如我们每次需要打出不同网络环境和不同证书的ipa, 由于开发者可以添加的设备只有100个, 而公司的几个项目都是用的一个账号, 各项 ...

  6. python项目打包部署到ios_Python iOS 自动打包脚本(包含上传到fir)

    Python iOS自动打包脚本 使用说明 1.1 使用python3编写,没有python3 环境的需要下载python3 python官网下载 1.2 通过Homebrew安装Python3 1. ...

  7. ios自动化打包 替换icon 启动图 bid appname 额外资源

    ios自动化打包脚本 下载地址https://github.com/gwh111/package 打开后自行替换 icon 启动图 bid appname 额外资源 原理:最新的脚本还是一个个替换后再 ...

  8. Tomcat Jenkins iOS自动打包

    Tomcat Jenkins iOS自动打包 Jenkins 可以配合测试人员或者 CI 打包,主要作用是提供打包页面选择和参数传递,最后导出 ipa 包. 打包方式有如下几种 借助 Jenkins ...

  9. 【Android 逆向】逆向修改游戏应用 ( APK 解析工具 | 解包 -> 分析 -> 重打包 -> 签名 流程 )

    文章目录 一.APK 解析工具 二.解包 -> 分析 -> 重打包 -> 签名 流程 一.APK 解析工具 使用 [Android 逆向]使用 Python 编写 APK 批处理分析 ...

最新文章

  1. 两行代码玩转 Google BERT 句向量词向量
  2. mybatis转义符(亲测)
  3. MATLAB数值计算与符号运算
  4. java null转换jason_常见java问题及解决办法汇总(干货可收藏)
  5. 学计算机耗脑子,为什么补脑——脑是耗能大户
  6. ina3221嵌入式linux,嵌入式Linux之我行——Linux-2.6.30.4在2440上的移植之文件系统
  7. Spring MVC数据绑定和表单标签的应用(附带实例)
  8. IPFS 相关开发资源汇总
  9. wps文字表格制作拼音田字格模板_宝宝拼音汉字田字格doc模板下载
  10. 一名优秀的数据分析师应该具备这10项关键技能
  11. 用计算机编程解决土方调配,LINGO在土方调配计算问题应用.doc
  12. python适合多大小孩学好拼音打字_都已经十七八岁的年龄了,突然发现自己居然不会拼音打字,现在想好好学,但是感觉无从下手。有什么方法么?...
  13. GitDown: 下载Github特定文件夹
  14. Linux学习——编辑器Vim学习
  15. Origin如何绘出带有时间轴的趋势图
  16. 编译错误:invalid types ‘int[int]‘ for array subscrip-markdown编辑器
  17. 小米数据收集利器:AgentSource
  18. 【算法思想:回溯法】回溯算法入门级详解
  19. Mac版3D动画建模渲染工具C4D R26
  20. java棒棒糖和皮卡丘八音盒_KFC用玩具提前要走了压岁钱

热门文章

  1. 强化学习从零开始从无到有
  2. 都说靠python接单一个月能赚好几千,事实真是如此吗?
  3. 自定义可存数据的jquery 表情输入框
  4. JAVA-数组和List转换
  5. 为什么神奇宝贝服务器显示显卡,为什么我的电脑玩我的世界之神奇宝贝画面很卡 是怎么回事 配置绝对不差 是什么原因造成的...
  6. ASM_ASMCMD用法
  7. 2019年计算机考研408联考【完整版】真题和答案!
  8. STM32按键的检测IO口上拉下拉电阻
  9. AI 让观众成为 3D 版《老友记》的导演了?
  10. 如何压缩 Microsoft Virtual PC 2007 虚拟硬盘文件(.VHD文件)