android - Android:HTTPCLIENT POST-无法将数据发送到服务器

标签 android httpclient gsoap

您好,我正在尝试使用httpclient将数据发送到服务器。

这是我的代码

public class MainActivity extends Activity implements OnClickListener {
private String TAG;

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

    Button press = (Button) findViewById(R.id.button1);
    press.setOnClickListener(this); 
}

@Override
public void onClick(View v) {
    switch (v.getId()) {
    case R.id.button1:

        String usrName = ((EditText) findViewById(R.id.usrName)).getText()
                .toString().trim();
        String age = ((EditText) findViewById(R.id.age)).getText()
                .toString().trim();

        Toast.makeText(getApplicationContext(),
                "username:: " + usrName + "---Age::" + age,
                Toast.LENGTH_SHORT).show();

        // Create a new HttpClient and Post Header
        HttpClient httpclient = new DefaultHttpClient();

        HttpPost httppost = new HttpPost("http://192.168.1.40"); 
        String resp = null;

        try {
            // create data to POST
            List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(
                    5);
            nameValuePairs.add(new BasicNameValuePair("UserName", usrName));
            nameValuePairs.add(new BasicNameValuePair("Age", age));

            httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs)); 

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

            resp = response.toString();

        } catch (ClientProtocolException e) {
            System.out.println("---" + e.getMessage());
        } catch (IOException e1) {
            System.out.println("---" + e1.getMessage());
        }

        Log.i(TAG, "RTT inside post-data: " + time_passed);

        Log.i(TAG, resp.toString());

        break;
    case R.id.send:

    default:
        break;
    }

}

}


我在logcat中收到此错误

 06-07 18:23:45.650: E/AndroidRuntime(2387): FATAL EXCEPTION: main
 06-07 18:23:45.650: E/AndroidRuntime(2387): android.os.NetworkOnMainThreadException
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at libcore.io.IoBridge.connect(IoBridge.java:112)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at java.net.Socket.connect(Socket.java:842)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at com.sakeesoft.android.MainActivity.onClick(MainActivity.java:104)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.view.View.performClick(View.java:3511)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.view.View$PerformClick.run(View.java:14105)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.os.Handler.handleCallback(Handler.java:605)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.os.Handler.dispatchMessage(Handler.java:92)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.os.Looper.loop(Looper.java:137)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at android.app.ActivityThread.main(ActivityThread.java:4424)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at java.lang.reflect.Method.invokeNative(Native Method)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at java.lang.reflect.Method.invoke(Method.java:511)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
 06-07 18:23:45.650: E/AndroidRuntime(2387):    at dalvik.system.NativeStart.main(Native Method)


请帮我知道HTTPClient的用处。
谢谢..

最佳答案

当应用程序尝试在其主线程上执行联网操作时引发的异常。

使用asynctask或Thread类进行网络调用。

关于android - Android:HTTPCLIENT POST-无法将数据发送到服务器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10932238/

相关文章:

Android StrictMode 总是提示 FileReader

java - HTTPRequest 似乎不起作用(在网络应用程序中注册用户)

web-services - Onvif 设备管理器找不到 Onvif 设备

c++ - 我可以自动调用 abcclientproxy.cpp 方法构建测试代码吗,由 gSOAP 2.8.16 从 abc.h 生成

android - RecyclerView 和 CardView Click 监听器实现

android - 为Android创建动态壁纸的要求

java - 如何在Android中使用DialogFragment进行文本输入?

c# - 如何使用 ASP.NET Core 依赖注入(inject)将 HttpMessageHandler 注入(inject)到 HttpClient 对象中?

php - Android:使用 HTTPClient 将日期对象发布到 PHP

ssl - 在 OpenSSL 中全局禁用协议(protocol)