Android : HTTPCLIENT POST - Not able to send data to server

被刻印的时光 ゝ 提交于 2019-12-11 04:48:24

问题


Hello I am trying to send data to server using httpclient.

Here is my code

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;
    }

}

}

I am getting this error in 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)

please help me know what worng with HTTPClient. Thanks..


回答1:


The exception that is thrown when an application attempts to perform a networking operation on its main thread.

Use asynctask or Thread class for network calls.



来源:https://stackoverflow.com/questions/10932238/android-httpclient-post-not-able-to-send-data-to-server

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!