Android: не может отправить http сообщение

Я бился головой, пытаясь понять, как отправить метод сообщения в Android. Вот как выглядит мой код:

public class HomeActivity extends Activity implements OnClickListener {

    private TextView textView;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        textView = (TextView) findViewById(R.id.text);
        Button button = (Button)findViewById(R.id.button);
        button.setOnClickListener(this);

    }

    @Override
    public void onClick(View view) {    
        HttpPost httpMethod = new HttpPost("http://www.example.com/");
        httpMethod.addHeader("Accept", "text/html");
        httpMethod.addHeader("Content-Type", "application/xml");


        AndroidHttpClient client = AndroidHttpClient.newInstance("Android");
        String result = null;
        try {
            HttpResponse response = client.execute(httpMethod);
            textView.setText(response.toString());

            HttpEntity entity = response.getEntity();

            Log.i(HomeActivity.class.toString(), result);
            textView.setText("Invoked webservice");
        } catch (IOException e) {
            e.printStackTrace();
            Log.e(HomeActivity.class.toString(), e.getMessage());
            textView.setText("Something wrong:" + e.getMessage());
        }
    }
}

Это исключение, которое я получаю:

I/ARMAssembler(   59): generated scanline__00000177:03515104_00001001_00000000 [
 91 ipp] (114 ins) at [0x334348:0x334510] in 1430659 ns
W/System.err(  272): java.net.UnknownHostException: www.example.com
W/System.err(  272):    at java.net.InetAddress.lookupHostByName(InetAddress.jav
a:513)
W/System.err(  272):    at java.net.InetAddress.getAllByNameImpl(InetAddress.jav
a:278)
W/System.err(  272):    at java.net.InetAddress.getAllByName(InetAddress.java:24
2)
W/System.err(  272):    at org.apache.http.impl.conn.DefaultClientConnectionOper
ator.openConnection(DefaultClientConnectionOperator.java:136)
W/System.err(  272):    at org.apache.http.impl.conn.AbstractPoolEntry.open(Abst
ractPoolEntry.java:164)
W/System.err(  272):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.o
pen(AbstractPooledConnAdapter.java:119)
W/System.err(  272):    at org.apache.http.impl.client.DefaultRequestDirector.ex
ecute(DefaultRequestDirector.java:348)
W/System.err(  272):    at org.apache.http.impl.client.AbstractHttpClient.execut
e(AbstractHttpClient.java:555)
W/System.err(  272):    at org.apache.http.impl.client.AbstractHttpClient.execut
e(AbstractHttpClient.java:487)
W/System.err(  272):    at org.apache.http.impl.client.AbstractHttpClient.execut
e(AbstractHttpClient.java:465)
W/System.err(  272):    at android.net.http.AndroidHttpClient.execute(AndroidHtt
pClient.java:243)
W/System.err(  272):    at com.collaboapp.android.HomeActivity.onClick(HomeActiv
ity.java:152)
W/System.err(  272):    at android.view.View.performClick(View.java:2408)
W/System.err(  272):    at android.view.View$PerformClick.run(View.java:8816)
W/System.err(  272):    at android.os.Handler.handleCallback(Handler.java:587)
W/System.err(  272):    at android.os.Handler.dispatchMessage(Handler.java:92)
W/System.err(  272):    at android.os.Looper.loop(Looper.java:123)
W/System.err(  272):    at android.app.ActivityThread.main(ActivityThread.java:4
627)
W/System.err(  272):    at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err(  272):    at java.lang.reflect.Method.invoke(Method.java:521)
W/System.err(  272):    at com.android.internal.os.ZygoteInit$MethodAndArgsCalle
r.run(ZygoteInit.java:868)
W/System.err(  272):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.ja
va:626)
W/System.err(  272):    at dalvik.system.NativeStart.main(Native Method)
E/class android.HomeActivity(  272): www.example.com
D/ThrottleService(   59): finally have imsi - retreiving data
D/ThrottleService(   59): onPollAlarm - roaming =false, read =0, written =0, new
 total =0
D/SntpClient(   59): request time failed: java.net.SocketException: Address fami
ly not supported by protocol

Что я здесь не так делаю? Что-нибудь, что мне может понадобиться настроить с эмулятора Android, чтобы это работало?

Спасибо за помощь.

4 ответа

Решение

Кажется, что AndroidHttpClient несет ответственность за это исключение. Ваш пример будет работать

  • если использовать, установите "Интернет", как предложено
  • заменить "AndroidHttpClient" на "DefaultHttpClient"
  • удалить строку "Log.i(HomeActivity.class.toString(), result);" потому что результат нулевой

Мне не понятно, почему этот класс не работает, как ожидалось, может быть, кто-то может объяснить. В этой теме также обсуждалась проблема, но также нет объяснения причин сбоя кода: http://groups.google.de/group/android-developers/browse_thread/thread/cc59efb9475ac557/81116369f2c6bd7a?hl=de&lnk=gst&q=This+thread+forbids+HTTP+requests.

Вы не можете вызывать веб из потока пользовательского интерфейса, поэтому не останавливаете пользовательский интерфейс приложения, этот пост в блоге объясняет это с помощью примера приложения, использующего AndroidHttpClient: официальный блог разработчика Android.

Вот цитата:

... это настолько плохая идея, что AndroidHttpClient не позволяет запускаться из основного потока. Приведенный выше код будет отображать сообщения об ошибке "Этот поток запрещает HTTP-запросы". Вместо этого используйте DefaultHttpClient, если вы действительно хотите выстрелить себе в ногу.

Так что, если вы действительно хотите запустить это в потоке пользовательского интерфейса (плохая идея, из личного опыта и этой записи в блоге), тогда используйте DefaultHttpClient.

Спасибо, я нашел это, я только что включил StrictMode

 public void onCreate() {
 if (DEVELOPER_MODE) {
     StrictMode.enableDefaults();
 }
 super.onCreate();

}

Есть ли у вас разрешение на использование в AndroidManifest.xml?

<uses-permission android:name="android.permission.INTERNET"></uses-permission>
Другие вопросы по тегам