本篇內(nèi)容主要講解“Android和iOS包中如何實現(xiàn)批量重簽名”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Android和iOS包中如何實現(xiàn)批量重簽名”吧!
成都創(chuàng)新互聯(lián)公司服務(wù)項目包括雙橋網(wǎng)站建設(shè)、雙橋網(wǎng)站制作、雙橋網(wǎng)頁制作以及雙橋網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,雙橋網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到雙橋省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!Android篇
環(huán)境要求
1 安裝winrar,然后配置winrar的環(huán)境變量,要用到winrar指令
2 配置java的bin目錄到環(huán)境變量,要用到j(luò)arsigner指令
重簽名步驟說明:
1 從母包復(fù)制一個子包
2 刪除子包的簽名文件META-INFO
3 根據(jù)需要修改子包的文件,比如渠道號文件之類
4 重簽名子包
對應(yīng)的python腳本
import os import sys import shutil import json ORIGINAL_APK='母包.apk' UNSIGN_APK='unsign.apk' SIGNED_APK={"\"子包1.apk\"":1,"\"子包2.apk\"":2,"\"子包3.apk\"":3,"\"子包4.apk\"":4} KEY_STORE='keystore文件.keystore' KEY_PASS='key密碼' STORE_PASS='store密碼' def copy_apk(src_f,dst_f): if not os.path.isfile(src_f): print("%s not exist"%(src_f)) else: fpath,fname=os.path.split(dst_f) shutil.copyfile(src_f,dst_f) print("copy %s -> %s"%(src_f,dst_f)) def zip_del_file(apk_f,del_f): os.system("winrar d %s %s"%(apk_f,del_f)) print('zip_del_file:'+del_f) def zip_add_file(apk_f,channel): del_dir("assets") os.makedirs("assets") f=open("assets\\AppParamSetting.txt",'w') f.write('{"channel":%s,"bundleIdentifier":""}'%(channel)) f.close() os.system("winrar a -ad %s %s"%(apk_f,"assets\\AppParamSetting.txt")) def del_file(f): os.remove(f) print('del_file:'+f) def del_dir(f_dir): if os.path.exists(f_dir): shutil.rmtree(f_dir) print("del_dir:"+f_dir) def sign_app(unsigned_app, signed_app): signcmd='jarsigner -verbose -keystore %s -keypass %s -storepass %s -signedjar %s -digestalg SHA1 -sigalg MD5withRSA %s sfish' % (KEY_STORE,KEY_PASS,STORE_PASS,signed_app,unsigned_app) os.system(signcmd) print(signcmd) if __name__ == '__main__': cur_dir=os.getcwd() print('cur_dir'+cur_dir) copy_apk(ORIGINAL_APK,"tmp_"+ORIGINAL_APK) zip_del_file("tmp_"+ORIGINAL_APK,"META-INF") for key in SIGNED_APK.keys(): channel=SIGNED_APK[key] zip_add_file("tmp_"+ORIGINAL_APK,channel) sign_app("tmp_"+ORIGINAL_APK,key) del_dir("assets") del_file("tmp_"+ORIGINAL_APK) input("Done")
iOS篇
環(huán)境要求:
1 mac機子
2 證書文件,打開:Launchapd(火箭圖標)->其他 -> 鑰匙串訪問,就在那里
3 .mobileprovision文件
重簽名步驟說明:
1 從.mobileprovision文件生成entitlements.plist文件
2 解壓ipa,會得到一個Payload目錄,再往里是一個xxx.app,顯示包內(nèi)容可以看到里面的東西
3 刪除簽名文件,即:Payload/xxx.app/_CodeSignature目錄
4 根據(jù)需要修改文件,比如渠道文件
5 重簽名
6 壓縮ipa
對應(yīng)的python腳本
#!/usr/bin/python import os import sys import json ORIGINAL_IPA='母包.ipa' SIGNED_APK={"\"子包1.ipa\"":1,"\"子包2.ipa\"":2,"\"子包3.ipa\"":3,"\"子包4.ipa\"":4} CERT_FILE='證書文件' MOBILE_PROVISION_UUID = 'mobileprovision的uuid' def get_mobile_provision_dir(): return os.path.join(os.getenv('HOME'),'Library/MobileDevice/Provisioning Profiles/') def get_mobile_provision_file(uuid): return os.path.join(get_mobile_provision_dir(), uuid + ".mobileprovision") def unzip_app(): os.system('unzip -qo ./%s -d ./'%(ORIGINAL_IPA)) print('unzip_app %s done!'%(ORIGINAL_IPA)) def del_code_signature(): os.system("rm -rf ./Payload/sfish.app/_CodeSignature") print('del_code_signature done!') def resign_app(): os.system('/usr/bin/codesign --continue -f -s "%s" --entitlements "%s" "%s"'%(CERT_FILE,'./entitlement.plist','./Payload/sfish.app')) print('resign_app done!') def zip_app(f_ipa): os.system('zip -r %s ./Payload'%(f_ipa)) print('zip_app done!') def del_payload(): os.system('rm -r ./Payload') def gen_entitlements(uuid, out_file_name): os.system('security cms -D -i "%s" > entitlement_full.plist '%(get_mobile_provision_file(uuid) )) os.system('/usr/libexec/PlistBuddy -x -c \'Print:Entitlements\' entitlement_full.plist > "%s" '%( out_file_name)) def rep_emb_file(uuid): os.system('cp "%s" ./Payload/sfish/embedded.mobileprovision' % (get_mobile_provision_file(uuid))) def update_channel_file(channel): f_channel='./Payload/xxx.app/Data/Raw/channel.txt' fr=open(f_channel,'r') txt=fr.read() fr.close() js=json.loads(txt) js['channel_id']=channel fw=open(f_channel,'w') fw.write(json.dumps(js)) fw.close() if __name__ == '__main__': gen_entitlements( MOBILE_PROVISION_UUID, "entitlement.plist" ) unzip_app() del_code_signature() for key in SIGNED_APK.keys(): channel=SIGNED_APK[key] update_channel_file(channel) resign_app() zip_app(key) del_payload()
到此,相信大家對“Android和iOS包中如何實現(xiàn)批量重簽名”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!
網(wǎng)站欄目:Android和iOS包中如何實現(xiàn)批量重簽名-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://www.rwnh.cn/article40/dciiho.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、軟件開發(fā)、自適應(yīng)網(wǎng)站、網(wǎng)站導(dǎo)航、網(wǎng)站營銷、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容