java - 在 Android 上请求发帖时出现问题

标签 java android http

当我尝试在 Android 应用程序上发出发布请求时,系统给出以下错误:

03-07 17:57:20.657: E/AndroidRuntime(2576): FATAL EXCEPTION: main
03-07 17:57:20.657: E/AndroidRuntime(2576): Process: sup.supreme, PID: 2576
03-07 17:57:20.657: E/AndroidRuntime(2576): java.lang.IllegalStateException: Could not execute method of the activity
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.view.View$1.onClick(View.java:3823)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.view.View.performClick(View.java:4438)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.view.View$PerformClick.run(View.java:18422)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.os.Handler.handleCallback(Handler.java:733)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.os.Handler.dispatchMessage(Handler.java:95)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.os.Looper.loop(Looper.java:136)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.app.ActivityThread.main(ActivityThread.java:5017)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.lang.reflect.Method.invokeNative(Native Method)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.lang.reflect.Method.invoke(Method.java:515)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at dalvik.system.NativeStart.main(Native Method)
03-07 17:57:20.657: E/AndroidRuntime(2576): Caused by: java.lang.reflect.InvocationTargetException
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.lang.reflect.Method.invokeNative(Native Method)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.lang.reflect.Method.invoke(Method.java:515)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.view.View$1.onClick(View.java:3818)
03-07 17:57:20.657: E/AndroidRuntime(2576):     ... 11 more
03-07 17:57:20.657: E/AndroidRuntime(2576): Caused by: android.os.NetworkOnMainThreadException
03-07 17:57:20.657: E/AndroidRuntime(2576):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.net.InetAddress.lookupHostByName(InetAddress.java:385)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.net.InetAddress.getAllByNameImpl(InetAddress.java:236)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at java.net.InetAddress.getAllByName(InetAddress.java:214)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
03-07 17:57:20.657: E/AndroidRuntime(2576):     at sup.supreme.MainActivity.find(MainActivity.java:88)

这是我用来发出请求的代码:

    HttpClient httpclient = new DefaultHttpClient();
    HttpPost httppost = new HttpPost(new Connection().Url()+":"+new Connection().Port()+"/Punche/ByName");

    try {
        // Add your data
        List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(1);
        nameValuePairs.add(new BasicNameValuePair("name", "n"));
        httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));

        // Execute HTTP Post Request
        HttpResponse response = httpclient.execute(httppost);

    } catch (ClientProtocolException e) {
        // TODO Auto-generated catch block
    } catch (IOException e) {
        // TODO Auto-generated catch block
    }

感谢您的帮助。

最佳答案

看起来您正在 ui 线程上运行网络代码。确保所有代码都在与 ui 线程不同的线程上运行。看here有关实现此目的的正确方法的示例。

关于java - 在 Android 上请求发帖时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22265975/

相关文章:

android - Flutter Android 版本构建签名失败

javascript - 通过脚本播放视频在 Android 上不起作用

http - 在 AngularJS 中,如何在查询更改时停止正在进行的 $http 调用

c - 使用C在套接字编程中获取请求的地址

angular - 如何使用我的 http 请求配置代理?

JavaDoc错误: datatypeConverter doesnot exist

java - Android 上缺少 HttpClientBuilder?

java - java : + versus += 精度损失

Java derby 数据库不工作

java - 如何在 Android 上的 Spinner 中使用 itemClickListener