【问题标题】:Android: Can not send http postAndroid:无法发送 http 帖子
【发布时间】:2010-06-13 11:22:13
【问题描述】:

我一直在绞尽脑汁想弄清楚如何在 Android 中发送 post 方法。这就是我的代码的样子:

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 模拟器配置什么才能使其正常工作吗?

感谢您的帮助。

【问题讨论】:

  • 您看到的错误/异常是什么?
  • 那么你怎么知道它不起作用呢?您能否查看服务器端的访问日志并看不到任何条目或中间有没有收到请求的代理?
  • @ZeissS。好的,现在我知道如何获取日志了。
  • 似乎您的 android 无法查找 DNS 条目 www.example.com。它有可用的互联网连接吗?
  • 是的。它有互联网连接。我可以使用模拟器的浏览器浏览互联网。

标签: java android http-post


【解决方案1】:

似乎 AndroidHttpClient 负责该异常。您的示例将起作用

  • 如果使用,请按照建议设置“INTERNET”权限
  • 将“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#81116369f2c6bd7a

【讨论】:

  • 它这样做是因为 HTTP 请求可能会阻塞 UI 线程。 AndroidHttpClient 只应该在后台线程上运行(例如在 AsyncTask 中)。 android-developers.blogspot.co.uk/2010/07/…“AndroidHttpClient不允许自己从主线程启动”
【解决方案2】:

您不能从 UI 线程调用 Web,因此您不会停止应用的 UI,这篇博文通过使用 AndroidHttpClient 的示例应用进行了解释:Official Android Dev Blog

这是一个引用:

...这是一个糟糕的主意,AndroidHttpClient 不允许自己从主线程启动。上面的代码将显示“此线程禁止 HTTP 请求”错误消息。如果您真的想在脚下开枪,请改用 DefaultHttpClient。

所以如果你真的想在 UI 线程上运行它(坏主意,从个人经验和那篇博客文章来看)然后使用 DefaultHttpClient。

【讨论】:

    【解决方案3】:

    您在 AndroidManifest.xml 中有使用权限吗?

    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
    

    【讨论】:

    • W/dalvikvm(261): threadid=1: 线程以未捕获的异常退出 (group=0x4 001d800) E/AndroidRuntime(261): FATAL EXCEPTION: main E/AndroidRuntime(261): java. lang.RuntimeException: 该线程禁止 HTTP 请求
    【解决方案4】:

    谢谢,我找到this,我刚刚启用了StrictMode

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

    }

    【讨论】:

      猜你喜欢
      • 2011-04-20
      • 2011-02-26
      • 1970-01-01
      • 1970-01-01
      • 2019-09-13
      • 1970-01-01
      • 2018-02-09
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多