Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Resign apk with different keystore

Tags:

Currently I'm getting the apk signed with the private keystore file but I want to sign that apk with different keystore file. How can I resign that apk..?

like image 534
Rookie Avatar asked Jun 06 '12 11:06

Rookie


People also ask

How do I resign an APK file?

apk file for resigning: Open up the . apk file in an archive manager and delete the entire META-INF directory with all of its contents. Ensure that the archive is saved upon closing it back up and keep the file extension as a .

How do I use Apksigner?

When you sign an APK using the apksigner tool, you must provide the signer's private key and certificate. You can include this information in two different ways: Specify a KeyStore file using the --ks option. Specify the private key file and certificate file separately using the --key and --cert options, respectively.


2 Answers

You can resign your apk with different keystore.

Follow these steps:

Signing for release: $1.apk -> $1_release.apk"

Step 1: Removing any previous signing

  • Change the extension of your .apk to .zip.
  • Open and delete the folder META-INF
  • Change the extension to .apk
    Or
    Command: zip [originalapk]
    Example: zip "$1".apk -d

Step 2: Signing with release.keystore:

Command:

jarsigner –verbose –keystore [keystorefile] –signedjar [unalignedapk] [originalapk] alias_name 

Example:

C:\Program Files\Java\jdk1.6.0_43\bin> jarsigner -verbose -keystore release.keystore -signedjar "$1"_unaligned.apk "$1".apk release 

Step 3: Aligning

Command: zipalign -f 4 [unalignedapk] [releaseapk]

Example:

C:\Users\Downloads\adt-bundle-windows-x86\adt-bundle-windows-x86\sdk\too ls>zipalign -f 4 "$1"_unaligned.apk "$1"_release.apk 

Step 4: Cleaning up

Command: rm 4 [unalignedapk]
Example: rm "$1"_unaligned.apk


Additional Commands might help:

  1. To generate new key with keytool
keytool -genkey -alias  -keystore  
  1. To list keys
keytool -list -keystore 

Note:

To sign our apks we have downgraded JDK from 1.7 to 1.6.0_43 update.

Reason:

As of JDK 7, the default signing algorithim has changed, requiring you to specify the signature and digest algorithims (-sigalg and -digestalg) when you sign an APK.

Command:

jarsigner -verbose -sigalg MD5withRSA -digestalg SHA1 -keystore [keystorefile] [originalapk] alias_name 
like image 150
Vihana Kewalramani Avatar answered Oct 06 '22 00:10

Vihana Kewalramani


you should check below SO thread

Can I resign an .apk with a different certificate

or this one also may help you

like image 37
swiftBoy Avatar answered Oct 05 '22 22:10

swiftBoy