iOS安全之ipa 包重签名的3种方法_ipa重签_沐雨07的博客-程序员秘密

技术标签: iResign 重签名方案  iOS 应用分身  ipa 包重签名  iOS安全  iOS ipa重签名工具 - iOS App Signer  iOS ipa重签名工具  

重签名的意义:ipa 重签名最大的用处是,不必重新打包,和配置其它第三方获取 appkey 等操作,直接重签名之后依然可以拥有这些功能,更快的发布测试或者灰度版本。

方法一、终端命令:sigh resign

1. 明白两个东西:想要重签名的证书和描述文件

开发证书或者企业证书,即你想要重签名的证书、provision描述文件。我是个人账户。没交钱的那种。(Xcode中自动管理会生成证书和描述文件)。

注意️:每一个重签版本都需重新申请一个 appid 和 provisoning profile,不然同appid的会覆盖。
mac电脑的开发环境配置

  1. 安装 homebrew,命令:
    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

  2. 安装 ruby,命令:brew install ruby更新 ruby 版本

  3. 安装 sigh,命令:sudo gem install sigh

如果出错那就换成gem install sigh安装过程是漫长的。(在安装 sigh 之前,你得检查 gem的镜像源,现在一般为https://gems.ruby-china.org)

准备好需要重签名的 ipa 包

自己的ipa 不用多说。编译一下在工程的Product 文件件下就有。也可以通过爱思助手下载具体教程:Mac 如何下载ipa

开始重签名

  • 第一步,把我们要重签名的 ipa 包和我们下载下来安装的 embedded.mobileprovison放在同一文件夹目录下,同级
  • 第二步,终端 cd 到这个 ipa 的文件夹目录下,执行sigh resign或者 fastlane sigh resign命令
  • 第三步:这时候,sigh 会直接弹出下面这个指令要你输入:Signing Identity这个就是你的证书的十六进制串,输入之后回车,然后等待见证奇迹的时刻吧。
    在这里插入图片描述
  • 第四步:验证我们重签的 ipa 包的时刻到了
先安装重签名之前的 ipa 包,然后再安装我们重签名之后的 ipa 包,如果没有覆盖,出现了两个一模一样的 App,各自点开没闪退没打不开的情况下,说明我们签名成功了。

sigh resign关于重签名有时候失败或者无法安装的情况说明。

如果ipa 里面有除了系统之外的 framework或者dylib的话,也需要先签名,不然也会导致签名后安装失败!至于 sigh 里面大致执行的脚本代码如下:

for framework in "$FRAMEWORKS_DIR"/*
do
 if [[ "$framework" == *.framework || "$framework" == *.dylib ]]
 then
     log "Resigning '$framework'"
     # Must not qote KEYCHAIN_FLAG because it needs to be unwrapped and passed to codesign with spaces
     # shellcheck disable=SC2086
     /usr/bin/codesign ${VERBOSE} ${KEYCHAIN_FLAG} -f -s "$CERTIFICATE" "$framework"
     checkStatus
 else
     log "Ignoring non-framework: $framework"
 fi
done

看得懂或者熟悉脚本的同学可以直接看脚本文件: resign.sh
位置:/Library/Ruby/Gems/2.3.0/gems/sigh-2.0.1/lib/assets/resign.sh
版本号是根据自己当前 sigh 插件的版本号决定的。

直接执行此脚本可以重签多 target 的 ipa:

./resign.sh YourApp.ipa "iPhone Distribution: YourCompanyOrDeveloperName" -p "bundel id"=<path_to_provisioning_profile_for_app>.mobileprovision -p "bundel id"=<path_to_provisioning_profile_for_watchkitextension>.mobileprovision -p "bundel id"=<path_to_provisioning_profile_for_watchkitapp>.mobileprovision -p "bundel id"=<path_to_provisioning_profile_for_todayextension>.mobileprovision resignedYourApp.ipa)

苹果的政策越来越收紧,这种方案的可行性的周期不确定。因为很多方案已经随着版本的更新,变得不可行了。从 iTunes 关闭了 ipa应该管理功能就知道了,对于包的安全性苹果越来越重视。另外,企业账号申请的难度越来越高,也有这种趋势。这种方法已经失败。

方法二、iResign 重签名方案

  1. 下载 iResign,下载完直接有个可执行的iResign.app,双击执行

  2. 参数路径跟图片上描述的很清楚,第一项是你要重签名的 ipa 的路径,第二项是我们重签名的配置描述文件的路径(不用改为 embedded 也可以),第四项,填写我们生成重签名用到的mobileprovisonbundle identifier,勾选修改 ID,第五项是我们重签名用到的mobileprovison的证书
    第三项很多教程说不用填,但是不填是无法自动生成的,会一直卡在entitlements generated这个步骤,无法生成。所以我们要自己生成entitlements.plist! 首先我们把要重签的 XXXX.ipa 解压后得到 Payload目录,然后终端 cd 到Payload目录下,执行以下命令:/usr/libexec/PlistBuddy -x -c "print :Entitlements " /dev/stdin <<< $(security cms -D -i XXXX.app/embedded.mobileprovision) > Entitlements.plist 其中 XXXX.app 是你要重签的 ipa的包名。生成的 entitlements.plist存放在Payload目录下,然后我们用 文本编辑或者 Xcode打开 plist 文件,修改里面的<key>application-identifier</key><string>PREFIX.yourappBundleID</string>为第四项填写的 bundle id。到此,配置完成,点击重新签名!

噔噔噔!签名成功请看下图:
在这里插入图片描述
iResign 使用注意事项:第三个 plist 文件是必填的,修改ID 的 bunle id 要跟 plist 修改的对应。

方法三、iOS ipa重签名工具 - iOS App Signer

  1. 下载 iOS App Signer 源码,运行在 May Mac 上
    在这里插入图片描述

  2. 第一项,填写我们需要重签名的 ipa 路径,第二项是我们要签名的证书,第三项选择我们配置的 provisoning profile(默认项Re-Sign Only 是无效的),然后,点击star!

在这里插入图片描述
此方式会自动分析 provisoning profile描述文件中的东西,所以不用我们自己填写变更的bundle id

验证得到ipa 直接在爱思助手中的:我的应用->中一拖就可以了。

这个方式亲自试了,比较简单方便。

结论:

但是最后重签名之前的能正常打开,重签名之后的都是一而退。暂时不知道什么原因。


感谢:
ipa重签名最直接的教程

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/shifang07/article/details/94755658

智能推荐

springMVC 注解驱动 出现[WARNING] No mapping for GET /_一234567博的博客-程序员秘密

学习黑马的springMVC入门时, 使用注解形式转化SpringMVC核心配置文件为配置类 访问静态资源时,出现[WARNING] No mapping for GET /在配置类上加了注解@EnableWebMvc后,再次启动可以正常访问,@EnableWebMvc作用是启用MVC 相当于&lt;mvc:annotation-driven /&gt;在讲师的视频和代码中没有@EnableWebMvc这个注解,视频是中是可以正常访问静态资源的,但我运行讲师的源代码也是报[WARNING]

Html网页设计-旅游景点介绍_html旅游景点网页_2033673808的博客-程序员秘密

项目运行截图资料说明Html网页设计-旅游景点介绍

vscode emmet默认模板_史上最全vscode配置使用教程_weixin_39648469的博客-程序员秘密

工欲善其事,必先利其器。想要优雅且高效的编写代码,必须熟练使用一款前端开发工具。但前端开发工具数不胜数,像HBuilder、Sublime Text、WebStorm、Visual Studio Code......等等,其中VSCode以其轻量且强大的代码编辑功能和丰富的插件生态系统,独受前端工师的青睐。网上有很多vscode的配置以及使用博客,但都没有本篇那么详细且全面。 软件下...

读博阶段需要注意的几个问题_enago的博客-程序员秘密

读博是个很难的事情,在申请读博之前就应该考虑清楚这两个问题。首先是自己是否需要读博。博士阶段主要是训练科研能力,如果将来不打算从事科研工作,那么就没有必要非要读博。其次看自己是否适合读博,一般来说读博都需要花大量的时间读文献、泡实验室跟写论文,要权衡一下自己是否能够沉得住几年的气,耐得住几年的寂寞,有没有足够的毅力和能力来渡过至少三年的博士生涯。当你顺利的成为了一名博士研究生后,首先要明确读博需...

程序员的微创业_weixin_33861800的博客-程序员秘密

不知道有没有觉得程序员是吃青春饭的;有没有发现很多公司的招聘需求上写着35岁以下不要;有没有发现一转眼都已奔三,却依旧一事无成,无房无车;怎么办?我想过创业,我也创业过,15年的时候和同学一块做人脸识别,种种原因最后没成功,此前两年的积蓄也清零,创业?人家都说是九死一生,我说就是,在你没有足够人脉钱脉的时候你去创业,无异于以卵击...

解决XshellXftpPortable.exe运行不了、打不开问题_余生-雨声的博客-程序员秘密

解决XshellXftpPortable.exe运行不了、打不开问题;1.首先点击控制面板----&gt;程序和功能,进入查看程序中是否下载了,Microsoft_Visual c++(05、08、12),由于XshellXftpPortable需要的运行程序版本较低,所以三个都需要下载安装,安装运行,如图所示:2.完成运行之后,需要重启电脑,重启完成之后如果还不能启动找到服务里面 Wind...

随便推点

Invalid URI_weixin_34327223的博客-程序员秘密

Infor syteline客户端WinStudio无法登录,出现下面错误提示: 解决方法:start menu &amp;gt; All programs &amp;gt; Info &amp;gt; tools &amp;gt; right-click Configuration Manager &amp;gt; configurations tag &amp;gt;选择您的配置文件,然后Click 编辑(Edit......

css3-使用多列制作瀑布流_RedGuy_anluo的博客-程序员秘密

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Title</title> <link href="countstyle.css" type="text/css" rel="stylesheet"></head><body> <div class="container">

CSS3 animation属性 与 @keyframes规则_白小明80583600的博客-程序员秘密

通过 @keyframes 规则,您能够创建动画。原理:将一套 CSS 样式逐渐变化为另一套样式。animation: name duration timing-function delay iteration-count direction fill-mode;@keyframes animationname {keyframes-selector {css-styles;}}

分享 15 个好用 + 实用的 Chrome 扩展_Java基基的博客-程序员秘密

点击上方“Java基基”,选择“设为星标”做积极的人,而不是积极废人!源码精品专栏原创 | Java 2020超神之路,很肝~中文详细注释的开源项目RPC 框架 Dubbo 源码解析网...

运维调试记录:Ubuntu14.04下部署Opendaylight Nitrogen集群_ubuntu14.04 karaf_KiteRunner24的博客-程序员秘密

建议参考官网教程:Setting Up Clustering一、实验环境主机节点系统版本: Ubuntu 14.04 (64bit)[email protected]:~$ uname -aLinux mpodl 4.2.0-27-generic #32~14.04.1-Ubuntu SMP Fri Jan 22 15:32:26 UTC 2016 x86_64 x86_64 x86...

阿里云博客搭建_闪电7的博客-程序员秘密

个人博客搭建过程 博客地址1.购买服务器(这里强烈建议阿里学生机)阿里学生机2.配置服务器1)配置防火墙端口 常用的MySQL nginx 项目使用端口2)设置远程连接密码 并用ssh工具连接 这里推荐Xshell xftp3)服务器配置环境这里需要配置环境 jdk MySQL nginx (后续更新环境安装博客)3. 项目打包(基于springboot项目)1)修改pom文件加入打包方式jar2)设置配置文件 端口 在服务器开放3)使用maven打包 先执行clean命令 在执行

推荐文章

热门文章

相关标签