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

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

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

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

NullPointerException

null値の参照型変数を参照しようとした場合に投げられる、Javaにおける例外のひとつです。

Java

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

Android

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

Q&A

2回答

3494閲覧

androidのHTTP通信でJSONファイル(文字列)を取得したい

shigashan

総合スコア8

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

NullPointerException

null値の参照型変数を参照しようとした場合に投げられる、Javaにおける例外のひとつです。

Java

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

Android

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

0グッド

0クリップ

投稿2017/11/04 13:07

編集2017/11/04 13:08

###前提・実現したいこと
Androidでhttp通信を行い、JSONファイルを取得しようとしています。
そこでまず、jsonファイルを文字列として取得し、それをどのクラスでも使用できるよう、publicなString型変数dataに代入し、別クラスからアクセスし、そこからJSONObjectに変換しようとしています。(一応getData()からアクセスしている)

###発生している問題・エラーメッセージ
他クラス(MainActivity)から試しにLog.d()でアクセスしようとしているのですが、NullPointerException例外が発生してしまいます。

E/AndroidRuntime: FATAL EXCEPTION: main Process: アプリ名, PID: 18636 java.lang.RuntimeException: Unable to start activity ComponentInfo{アプリ名/アプリ名.MainActivity}: java.lang.NullPointerException: println needs a message at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2320) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2380) at android.app.ActivityThread.access$800(ActivityThread.java:151) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1285) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:135) at android.app.ActivityThread.main(ActivityThread.java:5289) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:898) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693) Caused by: java.lang.NullPointerException: println needs a message at android.util.Log.println_native(Native Method) at android.util.Log.d(Log.java:139) at com.shigaki.sano.safetymap.MainActivity.onCreate(MainActivity.java:58) at android.app.Activity.performCreate(Activity.java:6018) at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2273) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2380)  at android.app.ActivityThread.access$800(ActivityThread.java:151)  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1285)  at android.os.Handler.dispatchMessage(Handler.java:102)  at android.os.Looper.loop(Looper.java:135)  at android.app.ActivityThread.main(ActivityThread.java:5289)  at java.lang.reflect.Method.invoke(Native Method)  at java.lang.reflect.Method.invoke(Method.java:372)  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:898)  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:693)

###該当のソースコード

//必要なクラスはすべてインポートしてあります。 public class MainActivity extends Activity{ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); HttpResponsAsync test = new HttpResponsAsync(); test.execute(); Log.d("test",test.getData()); //ここで例外発生 } } public class HttpResponsAsync extends AsyncTask<Void, Void, String> { String data; @Override protected void onPreExecute() { super.onPreExecute(); // doInBackground前処理 } @Override protected String doInBackground(Void... params) { // (1)try-catchによるエラー処理 try { // Basic認証のためUSERNAMEとPASSWORD等の設定をしてあります final String USERNAME = "ユーザー名"; //USERNAME,PASSWORDはちゃんと代入してます final String PASSWORD = "パスワード"; String strURL = "JSONファイルのURL"; //ここもちゃんと代入してます // (2)URLクラスを使用して通信を行う URL url = new URL(strURL); URLConnection connection = url.openConnection(); final String userPassword = USERNAME+":"+PASSWORD; final String encodeAuthorization = Base64.encodeToString(userPassword.getBytes(), Base64.NO_WRAP); connection.setRequestProperty("Authorization", "Basic " + encodeAuthorization); // 動作を入力に設定 connection.setDoInput(true); InputStream stream = connection.getInputStream(); BufferedReader input = new BufferedReader(new InputStreamReader( stream)); // (3)データの取得 String data = ""; String tmp = ""; while ((tmp = input.readLine()) != null) { data += tmp; } // (4)終了処理 stream.close(); input.close(); return data; } catch (Exception e) { // (5)エラー処理 return e.toString(); } } @Override protected void onPostExecute(String result) { super.onPostExecute(result); data = result; Log.d("testtest",data); //ここは正常に出力されます // doInBackground後処理 } public String getData(){ return this.data; } }

###試したこと
HttpResponseAsyncクラス内のonPostExecute()内でdataをLog.d()で出力してみたら、正常に出力されました。

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

guest

回答2

0

HttpResponsAsyncAsyncTaskの派生クラスです。Asyncとは**「非同期」と呼ばれる処理で、例えるならいま作業をしているあなたの代わりに作業をしてくれる作業員に「お願い」して「結果を後からもらう」ことです。ここではあなたはexecute「お願い」をしてgetData「結果を後からもらう」**という流れになります。例えばあなたが作業員に「このデータまとめといて」とお願いした直後に「もうできた?」と聞いたらできてるわけないですよね?作業員はまだ作業が終わっていないので、結果をくれと言われてもまだ結果はnullです。だからNullPointerExceptionが発生します。

投稿2017/11/06 01:35

masaya_ohashi

総合スコア9206

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

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

shigashan

2017/11/06 12:19

解答ありがとうございます。 大変わかりやすい説明で、なぜNullPointerExceptionになるのか理解できました。
guest

0

あなたはtest.execute()の行で処理が一時中断し、非同期処理が完了すると勝手にログ出力の行から再開されると思っていませんか?
ログ出力の行とonPostExecuteにブレークポイントを設置してどちらで先に停止するかを確認してください。

投稿2017/11/04 14:14

yona

総合スコア18155

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

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

shigashan

2017/11/06 02:22

回答ありがとうございます。ログ出力の方で先に停止してしまいました。 どうにかしてonPostExecuteを待つことはできないのでしょうか? また、もし他に良い解決策がありましたら教えていただけませんか?
yona

2017/11/06 03:25

コールバックについて調べて実装してください。 そうすることで、「終了を待つ」ではなく「終了の通知を待つ」という作りになります。
shigashan

2017/11/06 12:19

ありがとうございます。実装してみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問