Почему я должен перезагрузить Wi-Fi после httpPost () - PullRequest
1 голос
/ 27 декабря 2010

Разве вы не знаете, почему можно вызвать onClickListener только один раз, со второй попытки я должен включить и отключить соединение Wi-Fi на моем устройстве. После первого нажатия я не могу просматривать веб-страницы и читать электронную почту, поэтому подключение к Интернету заблокировано.

Code:
package je.net.ua;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class App extends Activity {

    Button button;
    TextView tv;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        button = (Button) findViewById(R.id.Button01);
        tv = (TextView) findViewById(R.id.TextView01);
        Log.d("Dev", "Application started");
        button.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                try {
                    BufferedReader in;
                    HttpClient client = new DefaultHttpClient();
                    HttpPost request = new HttpPost("http://www.snee.com/xml/crud/posttest.cgi");

                    List<NameValuePair> postParameters = new ArrayList<NameValuePair>();

                    postParameters.add(new BasicNameValuePair("fname", "First name"));
                    postParameters.add(new BasicNameValuePair("lname", "Last name"));

                    UrlEncodedFormEntity formEntity = new UrlEncodedFormEntity(
                            postParameters);

                    request.setEntity(formEntity);

                    HttpResponse response = client.execute(request);

                    in = new BufferedReader(new InputStreamReader(response.getEntity().getContent()));

                    StringBuffer sb = new StringBuffer("");
                    String line = "";
                    String NL = System.getProperty("line.separator");
                    while ((line = in.readLine()) != null) {
                        Log.d("Dev", "Line = " + line);
                        sb.append(line + NL);
                    }
                    in.close();
                    tv.setText(line);
                } catch (Exception ex) {
                }

            }
        });


    }
}

Debug:

12-27 21:39:16.936: DEBUG/Dev(6568): Line = <html><head><title>posted data</title></head><body><h1>posted data</h1><p>First name: "First+name"</p><p>Last name: "Last+name"</p><p>REQUEST_URI: "/xml/crud/posttest.cgi"</p><p>QUERY_STRING: ""</p><p>CONTENT_LENGTH: "32"</p><p>content passed via STDIN: "fname=First+name&lname=Last+name"</p></body></html>
12-27 21:39:25.566: DEBUG/dalvikvm(85): GC_FOR_MALLOC freed 28784 objects / 1536696 bytes in 109ms
12-27 21:39:34.106: DEBUG/dalvikvm(6072): GC_EXPLICIT freed 1097 objects / 213648 bytes in 67ms
12-27 21:39:42.476: DEBUG/dalvikvm(5056): GC_EXPLICIT freed 1749 objects / 72040 bytes in 53ms
12-27 21:39:47.516: DEBUG/dalvikvm(29993): GC_EXPLICIT freed 1378 objects / 67232 bytes in 91ms
12-27 21:39:50.136: WARN/GTalkService(21165): [GTalkConnection.11] doConnect: caught XMPPError connecting to mtalk.google.com:5228.: (502)
12-27 21:39:50.136: WARN/GTalkService(21165):   -- caused by: java.net.SocketException: The operation timed out

1 Ответ

4 голосов
/ 27 декабря 2010

Кажется, что ваш OnClickListener заблокирован, пока он ожидает ответа от http://www.snee.com/xml/crud/posttest.cgi. Выключение WiFi разрывает соединение с сокетом, поэтому ваш OnClickListener больше не блокируется в этот момент.

Если бы вы запускали основную часть этого обработчика как AsyncTask , я думаю, вы обнаружите, что можете нажать на кнопку любое количество раз (и залить свой сервер POST, когда вы сделай так; -)


Обновление

Ответ на ваше обновление, особенно в том, что Интернет и электронная почта заблокированы: похоже, были другие проблемы с отправкой POST через DefaultHttpClient. Я предлагаю вам изучить использование AndroidHttpClient , если вы нацелены на Froyo и более поздние выпуски, и обязательно вызывать его метод close () , когда закончите соединение. Или, если вам нужно придерживаться DefaultHttpClient, потому что вам нужно поддерживать более ранние выпуски, попробуйте позвонить client.getConnectionManager().shutdown(), когда вы закончите с подключением. Я не могу обещать, что эти шаги помогут, но они кажутся хорошими, несмотря ни на что.

(Из моего комментария ниже: Что произойдет, если вы выключите WiFi перед запуском программы? Блокирует ли она все еще возможность просматривать и отправлять электронную почту? Кроме того, вы видите возвращенный HTML после вызова tv.setText(line)? Наконец Я предлагаю помещать вызовы Log.d в ваш обработчик исключений и после цикла readLine() и посмотреть, достигнут ли один из них.)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...