Android httpclient.execute到web服务器上出现异常

Android httpclient.execute到web服务器上出现异常,android,exception,httpclient,Android,Exception,Httpclient,我尝试在web服务器上发送JSON数据,并通过此方法获得响应 public JSONObject postOnServer(JSONObject json) { HttpResponse response; JSONObject res = null; HttpClient httpclient = new DefaultHttpClient(); HttpConnectionParams.setConnectionTimeout(httpclient.get

我尝试在web服务器上发送JSON数据,并通过此方法获得响应

public JSONObject postOnServer(JSONObject json) {

    HttpResponse response;
    JSONObject res = null;

    HttpClient httpclient = new DefaultHttpClient();
    HttpConnectionParams.setConnectionTimeout(httpclient.getParams(), 10000);
    HttpPost httpPost = new HttpPost(PATH);

    try {

        //StringEntity stringEntity = new StringEntity("json", String.valueOf(json));
        ByteArrayEntity postMessage = new ByteArrayEntity(json.toString().getBytes("UTF8"));
        httpPost.setEntity(postMessage);
        response = httpclient.execute(httpPost);

        if (response.getStatusLine().getStatusCode() == 200) {

            InputStream instream = response.getEntity().getContent();
            try {
                res = new JSONObject(convertStreamToString(instream));
            } catch (JSONException e) {
                // TODO Auto-generated catch block
                Log.i("Response JSON", e.toString());
            }

        } else {

            res = new JSONObject();
            try {
                res.put("error", "Unable to load page.");
            } catch (JSONException e) {
                // TODO Auto-generated catch block
            }

        }
    } catch (IOException ex) {

        Log.i("Connection.postOnServer", "1.try exception: "+ex);
        res = new JSONObject();
        try {
            res.put("error", "Synchronization is not enable: Connection has aborted.");
        } catch (JSONException e) {
            Log.i("Connection.postOnServer", "put exception: "+e);
        }

    }

    return res;
}
但它总是以行
response=httpclient.execute(httpPost)结束此异常

05-24 10:58:51.635: E/AndroidRuntime(4709): FATAL EXCEPTION: main
05-24 10:58:51.635: E/AndroidRuntime(4709): android.os.NetworkOnMainThreadException
05-24 10:58:51.635: E/AndroidRuntime(4709):     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at libcore.io.IoBridge.connectErrno(IoBridge.java:138)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at libcore.io.IoBridge.connect(IoBridge.java:112)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at java.net.Socket.connect(Socket.java:842)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
05-24 10:58:51.635: E/AndroidRuntime(4709):     at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)

有人知道如何修复它吗?如果我使用catch(IOException),应用程序就会被破坏。如果我使用catch(Exception)应用程序,则不执行任何操作。我应该如何发送数据?

Android不允许您在用户界面线程上运行网络请求。这是为了防止请求在执行时阻塞接口。您需要在单独的线程中执行请求。下面是一个例子:

new Thread(new Runnable() {
    //Thread to stop network calls on the UI thread
    public void run() {
        //Request the HTML
        try {
            HttpParams httpParameters = new BasicHttpParams();
            HttpConnectionParams.setConnectionTimeout(httpParameters, TIMEOUT_CONNECTION);
            HttpConnectionParams.setSoTimeout(httpParameters, TIMEOUT_SOCKET);

            HttpClient client = new DefaultHttpClient(httpParameters);
            HttpGet request = new HttpGet(getString(R.string.url));
            HttpResponse response = client.execute(request);

            //Do something with the response
        }
        catch (IOException e) {
            Log.e("Tag", "Could not get HTML: " + e.getMessage());
        }
    }
}).start();

同样的问题可能的重复,以及我如何从我执行该操作的方法返回该响应?您没有。如果您返回了一个响应,这意味着调用方法必须等待响应,因此您也可以不执行线程。需要进行的任何更新,都需要在执行网络调用的线程中进行。