Skip to content

KeyTool which runs in the actual Android device to create keystores for standalone developments for *.apk files.

License

Notifications You must be signed in to change notification settings

YutakaAoki/KeyTool

Repository files navigation

[From whom]

Yutaka Aoki(Japanese), NOWSMARTSOFT.
Date: 2019/05/07

-------------------------------------
[What is this ?]

This is a trasnport of KeyTool(Java, JDK 1.7) for android.
It is convenient for standalone developments of android applications
for signing *.apk files with a key.

keytool.dex which prebuilt version is included by this project
can be used to create keystore in the actual android device.

Since keytool.dex is from *.class made fully from *.java, it can be probably
run in almost all andorid devices.

Probably, the keystore which is created by this tool can be used
for signing *.apk package. But final testing has not been done yet.

Since this tool is a beta version, the full testing has not been done yet.

But dalvikvm executes this keytool.dex directly, and inputs name or
company name etc. from adb shell for the actual android device,
and outputs a keystore actually.

I have seen the outputed keystore file really in my real amazon Fire 7 tablet.

But I have not tested signing *.apk with it yet.

I have made keytool.dex first in 7th May, 2019 and just on the day
uploaded all sources and its prebuilt binary(*.dex).

This was built with JDK 1.7 source (GPL).
I choosed necessary sources and changed or commented out some codes.

"// YA" or "// YA, " begins before the first line of changed source.

------------------------------------------------------------------------
[Prerequisite]

1. Windows OS  (I have been using Win7, 64BIT, Pro.)
2. JDK
3. Android SDK
4. cygwin's tee (d:\cygwin\tee), if any.

Even if you don't have tee command, you can build this project.

------------------------------------------------------------------------
[[Important]]

The base path must NOT have any spaces.
The reason is that since "b-create-java-list.bat" uses simple
cmd.exe's dir /S /B command to create the list of *.java
under ./src directory and it is passed to javac.exe command
with @javalist.txt, if it includes any spaces, javac.exe
command will take one filename as two or more filenames.

For example :

[1] good example
C:\github\KeyTool\.git        # This is not needed to exist.
C:\github\KeyTool\src
C:\github\KeyTool\build
C:\github\KeyTool\...

[2] bad example
C:\Users\Taro Yamada\.git     # This is not needed to exist.
C:\Users\Taro Yamada\src
C:\Users\Taro Yamada\build
C:\Users\Taro Yamada\...

=======================================================
[[How to build]]

This project uses only cmd.exe's *.BAT file, javac.exe,
dx.bat to build the binary from source code.

javac.exe  : from JDK 1.7 or JDK 1.8
dx.bat     : from Android SDK
*.BAT      : from the source tree of this project.

------------------------------------
[First step to build]

-------------------------------------------------------
[1] set current directory

$ cd C:\github\KeyTool

------------
[2] open *.bat and modify an ANDROID_HOME variable.

change this to appropriate path value :
@set ANDROID_HOME=C:\Android\Sdk

-----------
[3] create javalist.txt

list up *.java files under src/ to the file javalist.txt.

$ b-create-java-list.bat

=======================================================
[[If you build with tee]]

-------------------------------------------------------
[3] src/*.java ---> javac ---> build/obj/*.class

$ b-compile.bat

-------------------------------------------------------
[4] build/obj/*.class ---> dx.bat ---> build/apk/keytool.dex

$ b-create-dex.bat


=======================================================
[[If you build without tee]]

-------------------------------------------------------
[3] src/*.java ---> javac ---> build/obj/*.class

$ c-compile-wo-tee.bat

-------------------------------------------------------
[4] build/obj/*.class ---> dx.bat ---> build/apk/keytool.dex

$ c-create-dex-wo-tee.bat

=======================================================
[[Test]]

Test uses build/apk/keytool.dex and adb.exe in host PC.

You need the following tools and files to test :

1. adb.exe    : Android Debugging Bridge from Android SDK

2. build/apk/keytool.dex : A keytool which format is dalvikvm byte code and is a final
                           target of this project to build.
                           But this file is distributed as prebuilt style from git download site.

Since keytool.dex is distributed as prebuilt style from git download site,
you can test it without any building steps from source codes.


-------------------------------------------------------
[1] PC: keytool.dex --> adb push --> andoird: /sdcard/keytool.dex

$ b-push-keytool-dex.bat

---------------------------------------------------
[2] output keytool's help message

$ b-run-keytool-dex-in-dev-help.bat


This is equivalent to the following :
--------------------------------------
adb shell cd /sdcard "&&" ^
   dalvikvm ^
   -cp keytool.dex ^
   main
--------------------------------------

---------------------------------------------
[3] test keytool

$ b-run-keytool-dex-in-dev-test.bat

This is equivalent to the following :
--------------------------------------
adb shell rm /sdcard/keystore.jks

adb shell cd /sdcard "&&" ^
   dalvikvm ^
   -cp keytool.dex ^
   main ^
   -genkeypair ^
   -keystore keystore.jks ^
   -alias androidkey ^
   -validity 10000 ^
   -keyalg RSA ^
   -keysize 2048 ^
   -storepass android ^
   -keypass android
--------------------------------------

About

KeyTool which runs in the actual Android device to create keystores for standalone developments for *.apk files.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages