質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

解決済

1回答

1668閲覧

証明書がGenerated Signed APKでビルドするとうまくいくが、通常「Run」ではうまくいかない

SmartBuzz

総合スコア81

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2017/10/30 12:10

証明書をBuild > Generated Signed APKでkeyAliasを入れて、keyPasswordを入れてビルドした時は実機にapkをメールで渡してインストールしてもうまくインストールされますが、なぜかRunまたはDebugでエミュレータにapkを流す際に生成されたapkをメールで渡してインストールしても、アプリが立ち上がる瞬間に落ちてしまいます。

落ちた際のログは以下です。

log

110-30 20:49:20.545 19143-19143/? E/AndroidRuntime: FATAL EXCEPTION: main 2 Process: com.testApp.testApplication.alpha, PID: 19143 3 java.lang.RuntimeException: Unable to instantiate application com.testApp.testApplication.TestAppli: java.lang.ClassNotFoundException: Didn't find class "com.testApp.testApplication.TestAppli" on path: DexPathList[[zip file "/data/app/com.testApp.testApplication.alpha-1/base.apk"],nativeLibraryDirectories=[/data/app/com.testApp.testApplication.alpha-1/lib/arm64, /vendor/lib64, /system/lib64]] 4 at android.app.LoadedApk.makeApplication(LoadedApk.java:582) 5 at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4779) 6 at android.app.ActivityThread.access$1600(ActivityThread.java:154) 7 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1452) 8 at android.os.Handler.dispatchMessage(Handler.java:102) 9 at android.os.Looper.loop(Looper.java:224) 10 at android.app.ActivityThread.main(ActivityThread.java:5526) 11 at java.lang.reflect.Method.invoke(Native Method) 12 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 13 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 14 Caused by: java.lang.ClassNotFoundException: Didn't find class "com.testApp.testApplication.TestAppli" on path: DexPathList[[zip file "/data/app/com.testApp.testApplication.alpha-1/base.apk"],nativeLibraryDirectories=[/data/app/com.testApp.testApplication.alpha-1/lib/arm64, /vendor/lib64, /system/lib64]] 15 at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 16 at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 17 at java.lang.ClassLoader.loadClass(ClassLoader.java:469) 18 at android.app.Instrumentation.newApplication(Instrumentation.java:982) 19 at android.app.LoadedApk.makeApplication(LoadedApk.java:577) 20 at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4779)  21 at android.app.ActivityThread.access$1600(ActivityThread.java:154)  22 at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1452)  23 at android.os.Handler.dispatchMessage(Handler.java:102)  24 at android.os.Looper.loop(Looper.java:224)  25 at android.app.ActivityThread.main(ActivityThread.java:5526)  26 at java.lang.reflect.Method.invoke(Native Method)  27 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)  28 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)  29 Suppressed: java.lang.ClassNotFoundException: com.testApp.testApplication.TestAppli 30 at java.lang.Class.classForName(Native Method) 31 at java.lang.BootClassLoader.findClass(ClassLoader.java:781) 32 at java.lang.BootClassLoader.loadClass(ClassLoader.java:841) 33 at java.lang.ClassLoader.loadClass(ClassLoader.java:504) 34 ... 12 more 35 Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aja

2017/10/31 02:48

Signして作成したものをリリースという意味が無くなりますが、現実的にこの事が必要なのでしょうか?
SmartBuzz

2017/10/31 12:18

複数人で開発していて、少し進む度にapkをメールやチャットで送ることがあり、Build Variantでreleaseとdebugを切り替えたら、その設定でRunする度にSignされたapkを吐く方が便利だなと思い、この実装を実現しようとしています。。
guest

回答1

0

ベストアンサー

署名を付けたい場合は、releaseやdebugに、signingConfigの設定を入れるだけで大丈夫かと思います。
(Google Playをデバッグモードで・・というような場面で使われる方法です)

ただ、今回のログでは、ClassNotFoundExceptionが出ているようですね。
署名が問題となる場合は、異なるエラーが出るかと思います。
(例) 参考資料から引用

app-release-unsigned.apk is not signed.

Please configure the signing information for the selected flavor using the Project Structure dialog.

もしかしたら、フレーバーによってパッケージ名を変えていませんか?

Process: com.testApp.testApplication.alpha
Didn't find class "com.testApp.testApplication.TestAppli"

Generate signed apkが通っているので、(Releaseモードの)Runで落ちる所が説明できませんが、パッケージ名を確認されてみてはいかがでしょうか。

参考資料:
https://stackoverflow.com/questions/25001479/app-release-unsigned-apk-is-not-signed
※回答に一部冗長な設定(debuggableなど)が入っているようです。ご注意を。

投稿2017/11/11 12:38

toris-birds

総合スコア122

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

SmartBuzz

2017/11/14 04:22

回答遅くなり申し訳ありません。 デバッグ用とリリース用の両方をインストールできるように、buildTypeのdebugの方は applicationIdSuffix = '.alpha' を追記しているので、パッケージ名は2つあるかもしれません。 ただ、ソースコード内容がほぼ同じの別アプリでは、なんら問題なくそれのパッケージ名だけを一斉置換で置き換えた今回作成しているアプリだけで、このような現象が起きるのが腑に落ちないところです。。
toris-birds

2017/11/15 07:56 編集

Androidの場合、パッケージ名の扱いは少し複雑で、いわゆる「パッケージ名」(ソースのpackage等で指定する値)を使うものや、ApplicationIDをパッケージ名として使うものなどが混在しています。また、Intent等でコンテキストを渡して使うタイプの物は、アプリのインストール時の情報からパッケージ名を取得している場合もあります。なので、パッケージ名の(文字列での)決め打ちをされた場合、物によってうまく動かないなどの現象が発生する場合もあるかと思います。
SmartBuzz

2017/11/16 06:44

なるほど。。。 という事は、エミュレーターにしても実機にしても一回完全にアンインストールしてやってから、再度インストールすれば、コメント頂いた現象が発生しにくくなるという事でしょうか??
toris-birds

2017/11/17 00:28

そうですね。一回アンインストールした方が確実かもしれません。ただ、アプリのデータ等も消すことになるので、その点だけ注意が必要かと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問