2013年11月19日火曜日

AndroidのapkのAndroidManifestを編集してリコンパイルする方法





前提

どこかしらから入手したapkがあるとする。
android sdkのplatform-toolsにpathを通してある。

  1. apktoolから以下の2つのファイルをダウンロードしてくる。
    ・apktool1.5.2.tar.bz2(2013/11/19時点)
    ・apktool-install-linux-r05-ibot.tar.bz2(2013/11/19時点)

  2. 2つのファイルを解凍する。
    $bzip2 -dc apktool1.5.2.tar.bz2 | tar xvf -
    $bzip2 -dc apktool-install-linux-r05-ibot.tar.bz2 | tar xvf -

    それぞれディレクトリ構成は、


    ・apktool
    /apktool1.5.2/apktool.jar

    apktool-install-linux-r05-ibot
    /apktool-install-linux-r05-ibot/aapt
    /apktool-install-linux-r05-ibot/apktool

  3. apktool.jarapktoolを同一ディレクトリに格納。
    ついでにapktoolを分かりやすいようにapktool.shとかにrenameしておく。
    ここでは、ディレクトリを/home/xxx/apktool/とする。

    /home/xxx/apktool/apktool.jar

    ・/home/xxx/apktool/apktool.sh

  4. apkをデコンパイルする
    上記のディレクトリにapkをおいて以下のコマンドを実行

    $./apktool.sh d old.apk

    するてと apkがデコンパイルされ、old ディレクトリが作成される。

  5. AndroidManifest.xmlを修正する。
    old ディレクトリの中にある
    AndroidManifest.xmlを思うがままに修正する。


  6. コンパイルする
    以下のコマンドを実行


    $./apktool.sh b old new.apk

    するてと new.apk が作成される。


  7. apkに署名する
    署名に必要な非公開鍵の生成と管理を行うにはkeytoolが必要。

    keytoolを使ったキーストアファイル(.keystore)の作成と非公開鍵(=キー)の生成の仕方は省略。
    知りたい方はこちらのページへ。

    ってことで、.keystoreを使って以下のコマンドで署名を行う。

    jarsigner -sigalg SHA1withDSA -digestalg SHA1 -verbose -signedjar <署名後のapk名> -keystore <キーストアファイルへのパス> 
    <署名前のapk名> <キーストアのalias>

    するてと、無事署名されたapkが出来上がる。

  8. おわり

0 件のコメント:

コメントを投稿