1

シンプルな画像をサーバーに送信しようとした小さなAndroidアプリケーションを開発しています。私の問題は、ヘッダー content-length を追加しようとすると、エラー http クライアント プロトコル例外が発生することです。私のコード構造は次のようになります..

@Override
protected Void doInBackground(Void... unused) {

    HttpClient hc = new DefaultHttpClient();
    String message;
    HttpPut p = new HttpPut("https://abc.com");
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    bitmap.compress(CompressFormat.JPEG, 100, bos);
    byte[] data = bos.toByteArray();

    try {
        int size = data.length;
        p.setEntity(new ByteArrayEntity(data));

        p.setHeader("Content-Length", Long.toString(data.length));
        //p.setHeader("Content-Length", "0");
        //p.setHeader("Content-type", "application/json");

        HttpResponse resp = hc.execute(p);
        if (resp != null)
        {
            if (resp.getStatusLine().getStatusCode() == 204)
            {

            }
        }

        Log.d("Status line", "" + resp.getStatusLine().getStatusCode());
    } catch (Exception e) {
        e.printStackTrace();
    }
    return null;
}

@Override
protected void onProgressUpdate(Void... unsued) {

}

@Override
protected void onPostExecute(Void result) {
    try {
        if (dialog.isShowing())
            dialog.dismiss();
        Log.i("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@", "before exception "+result);

    } catch (Exception e) {
        Log.i("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@", "inside catch ");
        Toast.makeText(getApplicationContext(),"Error"+e,
                Toast.LENGTH_LONG).show();
        Log.e(e.getClass().getName(), e.getMessage(), e);
    }
}

私は正しいことをしていますか?この問題を解決する方法。助けが必要。ありがとうございました。

私のエラートレースは次のようになります

03-16 10:02:47.663: W/System.err(5804): org.apache.http.client.ClientProtocolException
03-16 10:02:47.687: W/System.err(5804):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:557)
03-16 10:02:47.687: W/System.err(5804):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
03-16 10:02:47.687: W/System.err(5804):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
03-16 10:02:47.687: W/System.err(5804):     at com.example.profileimage.ImageUpload$ImageUploadTask.doInBackground(ImageUpload.java:243)
03-16 10:02:47.687: W/System.err(5804):     at com.example.profileimage.ImageUpload$ImageUploadTask.doInBackground(ImageUpload.java:1)
03-16 10:02:47.687: W/System.err(5804):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
03-16 10:02:47.687: W/System.err(5804):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
03-16 10:02:47.687: W/System.err(5804):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
03-16 10:02:47.687: W/System.err(5804):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
03-16 10:02:47.687: W/System.err(5804):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
03-16 10:02:47.687: W/System.err(5804):     at java.lang.Thread.run(Thread.java:1019)
03-16 10:02:47.687: W/System.err(5804): Caused by: org.apache.http.ProtocolException: Content-Length header already present
03-16 10:02:47.695: W/System.err(5804):     at org.apache.http.protocol.RequestContent.process(RequestContent.java:70)
03-16 10:02:47.695: W/System.err(5804):     at org.apache.http.protocol.BasicHttpProcessor.process(BasicHttpProcessor.java:290)
03-16 10:02:47.695: W/System.err(5804):     at org.apache.http.protocol.HttpRequestExecutor.preProcess(HttpRequestExecutor.java:160)
03-16 10:02:47.695: W/System.err(5804):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:401)
03-16 10:02:47.695: W/System.err(5804):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
03-16 10:02:47.695: W/System.err(5804):     ... 10 more
4

1 に答える 1

2

未回答の質問リストから外すには:


エラーは

「原因: org.apache.http.ProtocolException:Content-Lengthヘッダーが既に存在する」.

setHeader() を削除します。必要ありませんContent-Length。含めたエンティティに基づいて HttpPut が設定されます。手動で行う理由はありません。

于 2015-11-23T18:53:40.490 に答える