美文网首页iOS逆向
4-iOS签名与重签名

4-iOS签名与重签名

作者: 木羊君 | 来源:发表于2019-01-28 10:47 被阅读0次

一.iOS签名

    苹果为了解决应用滥用

    a.限制在苹果后台注册过的手机才可以安装,b.限制签名只能针对某一个具体的App,c第三控制App的权限  以上所有包含在entitlements描述文件里,XCode会自动打包到App内。

    开发时,编译完App,XCode用本地私钥M对App进行签名,同时把公钥M通过CSR文件通过苹果后台生成的cer证书和pp描述文件(设备信息、AppID信息、授权文件)打包进App内,文件名为embedded.mobileprivision。App安装到手机后,系统进行验证。

二.iOS手动重签名

    1.查看当前钥匙串可用于重签名的信息

        "security find-identity -v -p codesigning",选择要用于替换的"Minwen Zha"签名证书

    2.未越狱应用砸壳,已越狱应用直接使用 

        显示包内容,进入Payload, cd xxx.app   显示包内容,可执行文件的目录

        通过 "otool -l 可执行文件 | grep crypt" 查看 crypyid 是否为0,0已越狱

        备注:此时crypyid 可能为多个,"file 可执行文件"可查看包架构。(例:Mach-O executable arm_v7, Mach-O 64-bit executable arm64)

    3.显示包内容,可执行文件的目录。删除不可签名的内容

        a.删除 Plugins目录,里面是extension,包含 .appex文件,无法签名

        b.删除Watch目录

    4.对Frameworks目录里所有第三方framework重签名

        "codesign -fs "iPhone Developer:  Minwen Zha (FM4M7NHC99)" GPUImage.framework"

    5.可执行文件目录下,复制pp文件,修改bundleID

        a.拷贝"Minwen Zha"对应的pp描述文件到 可执行文件 所在的目录

        b.修改Info.plist文件的bundleID为pp描述文件对应的bundleID

    6.查看"Minwen Zha"证书对应pp描述文件

        "security cms -D -i 4ccc-cc-cc-cc-ccc.mobileprovision"

        a.拷贝<key>Entitlements<key>下对应的<dict> </dict>

        b.XCode新建 entitlements.plist,粘贴进去。

        c.拷贝到entitlements.plist文件到可执行文件目录上层(xxx.app目录),用来签名整个app包

    7.对整个包重签名

       "codesign -fs "iPhone Developer:  Minwen Zha (FM4M7NHC99)" --no-strict --entitlements=entitlements.plist xxx.app"

        查看当前app签名信息 "codesign -d -vv xxx.app"

    8.重新打包app安装

        a.重新打包"zip -ry xxx.app Payload" 

        b.运行初始工程,安装pp文件到手机    

        c.打开XCode,进入 Devices & Simulaotrs,点 +

三.XCode重签名

    0.解压ipa

        unzip xxx.ipa

    1.查看当前钥匙串可用于重签名的信息

        "security find-identity -v -p codesigning",选择要用于替换的"Minwen Zha"签名证书

    2.未越狱应用砸壳,已越狱应用直接使用 

        cd xxx.app   显示包内容,可执行文件的目录

        通过 "otool -l 可执行文件 | grep crypt" 查看 crypyid 是否为0,0已越狱

        备注:此时crypyid 可能为多个,"file 可执行文件"可查看包架构。(例:Mach-O executable arm_v7,     Mach-O 64-bit executable arm64)

    3.显示包内容,可执行文件的目录。删除不可签名的内容

        a.删除 Plugins目录,里面是extension,包含 .appex文件,无法签名

        b.删除Watch目录

    4.对Frameworks目录里所有第三方framework重签名

        "codesign -fs "iPhone Developer:  Minwen Zha (FM4M7NHC99)" GPUImage.framework"

    5.重新生成包

        zip -qr xxx.ipa Payload/

    6.替换掉.app

         XCode新建同名工程,编译生成xxx.app包,字节替换,运行真机

四.Shell脚本重签名

    ls -l 文件,查看文件的权限, -rwxrwxrwx 当前用户 | 当前组 | 其他用户,chmod修改权限 r4 w2 x1

    新建工程,工程->targets->Build Phases->+->New Run Script Phase->Shell  ${SRCROOT}/signApp.sh  chmod +x signApp.sh

    #1.0资源目录,里面放的ipad包

        ASSETS_PATH="${SRCROOT}/APP"

    #1.1temp目录,放解压的app

        TEMP_PATH="${SRCROOT}/Temp"

    #1.2目标ipa包路径

        TARGET_IPA_PATH="${ASSETS_PATH}/*.ipa"

    #1.3清空Temp目录

        rm -rf "${SRCROOT}/Temp"

        mkdir -p "${SRCROOT}/Temp"

    #1.4----------解压缩

        unzip -oqq "TARGET_IPA_PATH" -d "TEMP_PATH"

    #1.5解压的临时app路径

        TEMP_APP_PATH=$(set -- "$TEMP_PATH/Payload/"*.app;echo "$1")

        echo "TEMP_APP_PATH"

    #2.0拷贝app

        TARGET_APP_PATH="$BUILT_PRODUCTS_DIR/$TARGET_NAME.app"

    #2.1拷贝 temp_app -> target_app

        cp -rf "$TEMP_APP_PATH/" "$TARGET_APP_PATH"

    #2.2删除无法签名的文件

        rm -f "$TARGET_APP_PATH/Plugins"

        rm -f "$TARGET_APP_PATH/Watch"

    #2.3修改Info.plist的BundleId,通过PlistBuddy修改

        # -c "Set :Key Value" "xx.plist"

        /usr/libexec/PlistBuddy -c "Set :CFBundleIdentifier $(PRODUCT_BUNDLE_IDENTIFIER)"     "$TARGET_APP_PATH/Info.plist"

    #2.4给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"

    #2.5重签名第三方app的frameword

    TARGET_FRAMEWORKS_PATH="$TARGET_APP_PATH/Frameworks"

    if [ -d "$TARGET_FRAMEWORKS_PATH"];

    then

    for FRAMEWORK in "$TARGET_FRAMEWORKS_PATH/"* 

    do 

    /usr/bin/codesign --force --sign "$EXPANDED_CODE_SIGN_IDENTITY" "$FRAMEWORK"

    done

    fi

    终端指令

        file 可执行文件  查看包架构

        codesign -d -vv 可执行文件

        security find-identity -v -p codesigning 列出钥匙串里可签名的证书

        codesign -fs "iPhone Developer: vv.@vv.com (FM4M7NHC99)" GPUImage.framework     强制替换签名

        chmod +x 可执行文件  给文件添加权限

相关文章

  • 4-iOS签名与重签名

    一.iOS签名 苹果为了解决应用滥用 a.限制在苹果后台注册过的手机才可以安装,b.限制签名只能针对某一个...

  • iOS应用重签名

    签名与重签名 签名:原始数据 --> HASH --> 原来的证书加密重签名:原始数据 -->HASH --> 现...

  • IOS逆向_密码学:重签名

    1. 重签名; 2. 重签名注意事项; 3. 重签名流程; 1. 重签名:破坏签名的安装包,可以通过对其重签名的操...

  • iOS开发逆向之应用重签名(上)

    本文主要介绍重签名的几种方式,以及如何对应用进行重签名, 应用重签名 从之前《iOS逆向应用签名》中可知,签名是指...

  • iOS 重签名过程探究

    注意:这里只探讨重签名的整个过程,不一定能签名成功,重签名建议使用MonkeyApp 一、手动签名 1. 查看签名...

  • iOS重签名

    重组 IPA (打包再签名) - 窥打包签名流程 iOS数字签名及ipa重签名 ipa重签名的四种方式 ios 企...

  • APP手动重签

    APP的重签名是一个博弈的过程, 重签名的步骤随着Apple签名细节的修改也会有所改变对APP的重签名, 目前并不...

  • Xcode插件安装、误点Skip Bundles处理、升级更新插

    Xcode重签名 Xcode 8 之后,如需安装插件,需要对Xcode进行重签名 证书申请 略 重签名命令 移除X...

  • iOS逆向-RSA的使用:代码签名(手动签名、脚本自动签名 《二

    请先看下面?的文章 iOS逆向-RSA的使用-证书签名、代码签名(手动签名、脚本自动签名 《一》) 脚本重签名 ...

  • 重签名

    重签名 手动签名 干掉Plugins(插件)文件夹 干掉Watch 签名frameworkscodesign -f...

网友评论

    本文标题:4-iOS签名与重签名

    本文链接:https://www.haomeiwen.com/subject/hizojqtx.html