ブログ

Android4以降のBillingServiceでNullPointerException

Google PlayのDeveloper Consoleで「クラッシュとANR」ってのがあって、割と頻繁に上がってくるレポート。
Eclipse経由で実機にインストールしてもADB経由でapkをインストールしても出ないんだけど、Google Playで公開して実行すると必ず出るエラー。

アプリ内課金で使用しているBillingServiceが落ちてるようです。
ちなみにですが、In-app BillingはいまだにVersion 2を使用しています。

stackoverflowにも全く同じエラーの相談が上がってて早速試してみたら解決しました!
Android InApp Purchase Null pointer exception

ちなみにエラーはこんな感じ。

java.lang.RuntimeException: Unable to start service com.hoge.BillingService@415801e8 with null: java.lang.NullPointerException
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2387)
at android.app.ActivityThread.access$1900(ActivityThread.java:127)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1221)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4511)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at jp.co.woodsmall.childcarediary.BillingService.onStart(Unknown Source)
at android.app.Service.onStartCommand(Service.java:438)
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2370)
... 10 more

【修正前】

@Override
public void onStart(Intent intent, int startId) {
    handleCommand(intent, startId);
}

【修正後】

@Override
public void onStart(Intent intent, int startId) {
    if (intent != null) {
        handleCommand(intent, startId);
    }
}

stackoverflowって英語なので、とっつきにくいですが、ここを読んでて解決することが最近多い。
Google MapがAndroid4.0以降で表示されなかった時も、こちらを参考にしました。
Android4.3でGoogle Mapが表示されない

BillingServiceってGoogleから提供されているものなのでエンジニアとしては、どうしても手を入れたくない部分なんですが。
Googleの優秀なエンジニアでも未来のバグは予測できない、ってことでしょうか。

株式会社woodsmallの小林でした。
http://woodsmall.co.jp/

スポンサードリンク

  • このエントリーをはてなブックマークに追加

関連記事

スポンサードリンク

 

30代半ばのオッサンが起業した話

プロフィール

kobayashi-profile
代表取締役CEO 小林 高志
1999年からシステムエンジニアとして、クライアントサーバのシステム構築、WEBシステムの開発、Androidアプリの企画・開発、iPhoneアプリの企画・マーケティング等に携わる。
2012年からカメラマンとして都内のスタジオに従事。
2012年、株式会社woodsmall創業。
2013年5月に代表取締役に就任。
自身の半生を綴った書籍を出版するのが、個人的な目標。
趣味は、カメラ・車・バイク・料理。

代表取締役の略歴はこちら

社長のブログについて

検索してもヒットしなかったアプリ開発に関する技術的な記事から、その時に思ったことなどを素直に書き綴っています。

スポンサードリンク

Facebook

twitter

対応エリア

株式会社woodsmallは、千葉県をはじめ関東エリア、関西エリアでのホームページ制作、アプリ開発(Android、iPhone)、システム開発、チラシ制作を承ります。

【千葉県エリア】
船橋市、市川市、習志野市、浦安市、鎌ヶ谷市、松戸市、柏市、成田市、佐倉市、千葉市中央区、千葉市花見川区、千葉市稲毛区、千葉市美浜区、千葉市若葉区、千葉市緑区、白石市などの千葉県エリア

【東京都エリア】
足立区、荒川区、板橋区、江戸川区、大田区、葛飾区、北区、江東区、品川区、渋谷区、新宿区、杉並区、墨田区、世田谷区、台東区、中央区、千代田区、豊島区、中野区、練馬区、文京区、港区、目黒区などの東京都エリア

【神奈川県エリア】
横浜市、川崎市、藤沢市、茅ヶ崎市、大和市、海老名市、座間市、綾瀬市、平塚市、寒川町、大磯町、二宮町などの神奈川県エリア

【埼玉県エリア】
さいたま市、川口市、蕨市、戸田市などの埼玉県エリア

【関東・関西エリア】
その他、茨城県、栃木県、群馬県の関東エリア、長野県、新潟県の甲信越エリア、大阪府の関西エリア、全国からのご依頼に対応させて頂きます。
(遠方の場合は電話やメール、LINE、Skypeでの打合せとなります。)

ページ上部へ戻る