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

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

ただいまの
回答率

89.70%

androidでweb上のJSONを取得したいが強制停止してしまう

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,251

aaaaaaaaaaaaaa

score 75

androidでweb上のjsonのデータを読み込もうとしていますが
実行後問題が発生してアプリが終了してしまいます。
どなたか助けてください。
manifestsには <uses-permission android:name="android.permission.INTERNET" />を記入しています。
あとライブラリーはApache HttpComponentsを使っています。
エラーログは以下のようになっています。

 E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #1
 E/AndroidRuntime: Process: com.tes.test.myapplication, PID: 18097
 E/AndroidRuntime: java.lang.RuntimeException: An error occured while executing doInBackground()
 E/AndroidRuntime:     at android.os.AsyncTask$3.done(AsyncTask.java:300)
 E/AndroidRuntime:     at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
 E/AndroidRuntime:     at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
E/AndroidRuntime:     at java.util.concurrent.FutureTask.run(FutureTask.java:242)
E/AndroidRuntime:     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
E/AndroidRuntime:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
E/AndroidRuntime:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
E/AndroidRuntime:     at java.lang.Thread.run(Thread.java:818)
E/AndroidRuntime:  Caused by: java.lang.IllegalArgumentException: Illegal character in path at index 0: [Ljava.lang.String;@3495432c
E/AndroidRuntime:     at java.net.URI.create(URI.java:730)
E/AndroidRuntime:     at org.apache.http.client.methods.HttpGet.<init>(HttpGet.java:75)
E/AndroidRuntime:     at com.tes.test.myapplication.MainActivity$AsyncHttpRequest.doInBackground(MainActivity.java:41)
E/AndroidRuntime:     at com.tes.test.myapplication.MainActivity$AsyncHttpRequest.doInBackground(MainActivity.java:28)
E/AndroidRuntime:     at android.os.AsyncTask$2.call(AsyncTask.java:288)
E/AndroidRuntime:     at java.util.concurrent.FutureTask.run(FutureTask.java:237)
E/AndroidRuntime:     at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 
E/AndroidRuntime:     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
E/AndroidRuntime:     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
E/AndroidRuntime:     at java.lang.Thread.run(Thread.java:818) 


ソースは以下のようになっています。

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        String url = "http://192.168.1.1/keziban/api/Post_api.php";//ローカルネット
        AsyncHttpRequest task = new AsyncHttpRequest(this);
        task.execute(url);
    }

    public class AsyncHttpRequest extends AsyncTask<String,Void,String> {
       private Activity MainActivity;
        public AsyncHttpRequest(Activity activity) {
            this.MainActivity = activity;
        }
        @Override
        protected String doInBackground(String...builder) {
            DefaultHttpClient objHttp = new DefaultHttpClient();
            HttpParams params = objHttp.getParams();
            HttpConnectionParams.setConnectionTimeout(params, 1000); //接続のタイムアウト
            HttpConnectionParams.setSoTimeout(params, 1000); //データ取得のタイムアウト
            String sReturn = "";
            try {
                HttpGet objGet = new HttpGet(builder.toString());
                HttpResponse objResponse = objHttp.execute(objGet);
                if (objResponse.getStatusLine().getStatusCode() < 400){
                    InputStream objStream = objResponse.getEntity().getContent();
                    InputStreamReader objReader = new InputStreamReader(objStream);
                    BufferedReader objBuf = new BufferedReader(objReader);
                    StringBuilder objJson = new StringBuilder();
                    String sLine;
                    while((sLine = objBuf.readLine()) != null){
                        objJson.append(sLine);
                    }
                    sReturn = objJson.toString();
                    objStream.close();
                }
            } catch (IOException e) {
                return null;
            }
            return sReturn;
        }
        @Override
        protected void onPostExecute(String result) {
            //TextView tv = (TextView) MainActivity.findViewById(R.id.name);
            //tv.setText(result);
        }
    }

どうかよろしくおねがいします。
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • yona

    2015/11/02 16:58

    質問を修正し、エラーログを追記してください。

    キャンセル

  • yona

    2015/11/02 17:18

    抜粋ではなく全てのエラーログを追記してください。とくにcause byと書かれているところが重要です。

    キャンセル

回答 2

+1

protected String doInBackground(String...builder) {
    // 中略
}
このメソッドの引数は...から分かるように、可変長引数です。

HttpGet objGet = new HttpGet(builder.toString());
つまり、ここのbuilderは配列なのです。

質問者さんは、おそらく「http://192.168.1.1/keziban/api/Post_api.php」を想定していたのだと思いますが、配列をtoStringしているため、メタ情報「[Ljava.lang.String;@3495432c」(Stringの配列で、ハッシュコードが3495432c、という意味)の文字列が返ってきてしまっています。
これはどう見てもURLの書式ではなく、そのため例外が発生しています。

そのあたりのことは、ログのここを読めば全て分かります。
E/AndroidRuntime:  Caused by: java.lang.IllegalArgumentException: Illegal character in path at index 0: [Ljava.lang.String;@3495432c
E/AndroidRuntime:     at java.net.URI.create(URI.java:730) 
E/AndroidRuntime:     at org.apache.http.client.methods.HttpGet.<init>(HttpGet.java:75) 
E/AndroidRuntime:     at com.tes.test.myapplication.MainActivity$AsyncHttpRequest.doInBackground(MainActivity.java:41)


直し方としては、そもそも型がStringなので、toStringを使わず、そのまま配列の要素0番目を使えばよいかと思います。
HttpGet objGet = new HttpGet(builder[0]);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

checkベストアンサー

0

doInBackground(String...builder) 
この引数は可変引数といって、Stringの配列となっています。
そうすると、下記の記述は配列をtoStringしているため、予想外の動きとなります。
HttpGet objGet = new HttpGet(builder.toString());
正しくは下記の通りです。
HttpGet objGet = new HttpGet(builder[0]);

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2015/11/02 19:37

    上記の方法で上のエラーはなくなりましたが、次はこのようなエラーが出ました。
    以下のエラーはライブラリーの問題でしょうか。
    E/AndroidRuntime: Caused by: java.lang.NoSuchMethodError: No virtual method execute(Lorg/apache/http/client/methods/HttpUriRequest;)Lorg/apache/http/client/methods/CloseableHttpResponse; in class Lorg/apache/http/impl/client/DefaultHttpClient; or its super classes (declaration of 'org.apache.http.impl.client.DefaultHttpClient' appears in /system/framework/ext.jar)

    キャンセル

  • 2015/11/02 19:49

    Gradleのライブラリ読み込みを変更する必要があるそうです。

    HttpClient : httpclient-4.0-beta2.jar HttpCore : httpcore-4.1.jar

    詳しくは下記を参照ください。
    http://stackoverflow.com/questions/32328469/getting-error-in-asynctask-when-using-httpclient-and-http-core-library

    キャンセル

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

  • ただいまの回答率 89.70%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる