1

phpページにリクエストを送信するコードがあり、正常に機能しましたが、突然(何も変更したことを覚えていません)、エミュレーターと実際のデバイスの両方で機能しなくなりました

    URL url = new URL(this.site); 
            URLConnection conn = url.openConnection();

            if (!(conn instanceof HttpURLConnection))    { 
                Log.e(TAG, "connection is not HttpURLConnection");  
                throw new IOException("Not an HTTP connection");

            }

            try{
                Log.e(TAG, "Trying");
                HttpURLConnection httpConn = (HttpURLConnection) conn;
                Log.e(TAG, "Created connection");
                httpConn.setAllowUserInteraction(false);
                httpConn.setInstanceFollowRedirects(true);
                httpConn.setRequestMethod("POST");
                Log.e(TAG, "connecting");
                httpConn.connect(); 
                Log.e(TAG, "connected");

                OutputStreamWriter wr = new OutputStreamWriter(httpConn.getOutputStream());
                Log.e(TAG, "created outputstream");

スタックトレースは次のとおりです。

     12-25 00:32:14.024: W/System.err(885): java.net.ProtocolException: Does not support output
     12-25 00:32:14.090: W/System.err(885):     at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getOutputStream(HttpURLConnectionImpl.java:575)
     12-25 00:32:14.090: W/System.err(885):     at com.*****.StringAsyncRetriever.OpenHttpConnection(StringAsyncRetriever.java:122)
     12-25 00:32:14.090: W/System.err(885):     at com.******.StringAsyncRetriever.getData(StringAsyncRetriever.java:66)
     12-25 00:32:14.094: W/System.err(885):     at com.******.StringAsyncRetriever.doInBackground(StringAsyncRetriever.java:38)
     12-25 00:32:14.094: W/System.err(885):     at com.******.StringAsyncRetriever.doInBackground(StringAsyncRetriever.java:1)
     12-25 00:32:14.094: W/System.err(885):     at android.os.AsyncTask$2.call(AsyncTask.java:185)
     12-25 00:32:14.094: W/System.err(885):     at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)
     12-25 00:32:14.094: W/System.err(885):     at java.util.concurrent.FutureTask.run(FutureTask.java:138)
     12-25 00:32:14.094: W/System.err(885):     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)
     12-25 00:32:14.094: W/System.err(885):     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)
     12-25 00:32:14.094: W/System.err(885):     at java.lang.Thread.run(Thread.java:1019)
4

1 に答える 1

14

ソースコードを見ると、が:doOutputに設定されていない場合、その例外がスローされます。true

(From:http ://www.java2s.com/Open-Source/Android/android-core/platform-libcore/org/apache/harmony/luni/internal/net/www/protocol/http/HttpURLConnectionImpl.java.htm )。

public OutputStream getOutputStream() throws IOException {
    if (!doOutput) {
        throw new ProtocolException("Does not support output");
    }

このHttpURLConnectionImplクラスは、を拡張するJavaのHttpUrlConnectionクラスから拡張されていますURLConnection。そのためのjavadocを見ると、次のようになります。

保護されたブールdoOutput

この変数は、setDoOutputメソッドによって設定されます。その値は、getDoOutputメソッドによって返されます。URL接続は、入力および/または出力に使用できます。doOutputフラグをtrueに設定すると、アプリケーションがURL接続にデータを書き込もうとしていることを示します。

このフィールドのデフォルト値はfalseです。

したがって、次のことを行う必要があります。

httpConn.setDoOutput(true);

あなたのコードで。

于 2012-12-24T23:09:08.413 に答える