2

AsyncTask 内でサーバーとの接続を作成しています。HttpURLConnection を使用しています。URLでデータを送信しています。以下は、AsyncTask の doInBackground() メソッドのコードです。サーバーへのデータ送信を再試行しましたが、問題は解決しませんでした。Connection close ヘッダーも設定してみました。ただし、問題は引き続き発生します。

protected String doInBackground(String... url) {
    JSONObject body = new JSONObject();
    try {
        body.put("body","");
    } catch (JSONException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }

    mUploadChunkURL = url[0];
    System.out.println("length: " + mDataLength + " String length: " + String.valueOf(mDataLength));
    URL myurl;
    HttpsURLConnection con = null;
    while (numberOfTries < MAX_RETRIES) {
        try {
            myurl = new URL(mUploadChunkURL);
            con = (HttpsURLConnection)myurl.openConnection();
            con.setRequestMethod("POST");
            con.setConnectTimeout(1000*60*2);
            con.setRequestProperty("Content-Type","application/x-www-form-urlencoded"); 
            con.setDoOutput(true); 
            con.setDoInput(true);

            if (Build.VERSION.SDK != null
                    && Build.VERSION.SDK_INT > 13) {
                System.out.println("connection close");
                con.setRequestProperty("Connection", "close");
                    }

            DataOutputStream output = new DataOutputStream(con.getOutputStream());  
            output.writeBytes(body.toString());
            output.close();

            System.out.println("Resp Code: "+con.getResponseCode()); 
            System.out.println("Resp Message: "+ con.getResponseMessage()); 

            Log.e("64","Resp Message: "+inputLine.toString());

        } catch (IOException e) {
            Log.e("70", "IO exception: " + e.toString());
            e.printStackTrace();
        } catch (Exception e) {
            e.printStackTrace();
        } finally {

            if (con != null)
                con.disconnect();
        }

        numberOfTries++;
    }

    return null;
}

EOFException が発生しています。この行「System.out.println("Resp Code: "+con.getResponseCode());"」でこの例外が発生しています。以下はエラーログです。

05-23 15:46:25.281: W/System.err(16688): java.io.EOFException
05-23 15:46:25.281: W/System.err(16688):    at libcore.io.Streams.readAsciiLine(Streams.java:203)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpEngine.readHeaders(HttpEngine.java:608)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpEngine.readResponseHeaders(HttpEngine.java:561)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpEngine.readResponse(HttpEngine.java:813)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:274)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:486)
05-23 15:46:25.281: W/System.err(16688):    at libcore.net.http.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:134)
05-23 15:46:25.281: W/System.err(16688):    at com.utility.UploadFileChunk.doInBackground(UploadFileChunk.java:71)
05-23 15:46:25.296: W/System.err(16688):    at com.utility.UploadFileChunk.doInBackground(UploadFileChunk.java:1)
05-23 15:46:25.296: W/System.err(16688):    at android.os.AsyncTask$2.call(AsyncTask.java:287)
05-23 15:46:25.296: W/System.err(16688):    at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
05-23 15:46:25.296: W/System.err(16688):    at java.util.concurrent.FutureTask.run(FutureTask.java:137)
05-23 15:46:25.296: W/System.err(16688):    at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
05-23 15:46:25.296: W/System.err(16688):    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
05-23 15:46:25.296: W/System.err(16688):    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
05-23 15:46:25.296: W/System.err(16688):    at java.lang.Thread.run(Thread.java:856)

私を助けてください。

4

1 に答える 1

3

実際、URL の形式が正しくありませんでした。したがって、私はEOFExceptionを取得していました。URL で Base64 データを送信していましたが、データを Base64 に変換している間、NO_WRAP フラグを指定していませんでした。そのため、Base64 データは単一の長い行で送信されませんでした。

于 2014-05-29T07:25:32.363 に答える