0

我将下面给出的解析器与示例 Android 2.2 一起使用。我的例子正在工作,我没有问题。当尝试在使用 Android 4.3 的项目中使用某些示例时。但我的解析器行有问题

HttpResponse httpResponse = httpClient.execute(httpPost);

我检查了清单中的所有权限,所有权限都已使用。

public class JSONParser {

    static InputStream is = null;
    static JSONObject jObj = null;
    static String json = "";

    // constructor
    public JSONParser() {

    }

    public JSONObject getJSONFromUrl(String url) {

        // Making HTTP request
        try {
            // defaultHttpClient
            Log.d("test url" , "le request est lancé") ;
            DefaultHttpClient httpClient = new DefaultHttpClient();
            HttpPost httpPost = new HttpPost(url);
            HttpResponse httpResponse = httpClient.execute(httpPost);
            Log.d("test url" , "la connection etablie");
            HttpEntity httpEntity = httpResponse.getEntity();
            is = httpEntity.getContent();

        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(
                    is, "iso-8859-1"), 8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }
            is.close();
            json = sb.toString();
        } catch (Exception e) {
            Log.e("Buffer Error", "Error converting result " + e.toString());
        }

        // try parse the string to a JSON object
        try {
            jObj = new JSONObject(json);
        } catch (JSONException e) {
            Log.e("JSON Parser", "Error parsing data " + e.toString());
        }

        // return JSON String
        return jObj;

    }
}

日志是:

11-14 10:48:38.590: ERROR/AndroidRuntime(3801): FATAL EXCEPTION: main
        java.lang.RuntimeException: Unable to start activity ComponentInfo{fr.web.tab/fr.web.profilconfiguration.AndroidJSONParsingActivity}: android.os.NetworkOnMainThreadException
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981)
        at android.app.ActivityThread.access$600(ActivityThread.java:123)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147)
        at android.os.Handler.dispatchMessage(Handler.java:99)
        at android.os.Looper.loop(Looper.java:137)
        at android.app.ActivityThread.main(ActivityThread.java:4424)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:511)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
        at dalvik.system.NativeStart.main(Native Method)
        Caused by: android.os.NetworkOnMainThreadException
        at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1099)
        at java.net.InetAddress.lookupHostByName(InetAddress.java:391)
        at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
        at java.net.InetAddress.getAllByName(InetAddress.java:220)
        at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
        at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
        at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
        at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
        at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
        at fr.web.profilconfiguration.JSONParser.getJSONFromUrl(JSONParser.java:44)
        at fr.web.profilconfiguration.AndroidJSONParsingActivity.onCreate(AndroidJSONParsingActivity.java:62)
        at android.app.Activity.performCreate(Activity.java:4465)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920)
4

5 回答 5

4

不要在主线程中使用网络活动。此异常仅针对针对 Honeycomb SDK 或更高版本的应用程序引发。在单独的线程中执行所有与网络相关的任务。你的问题会得到解决。

于 2013-11-14T10:28:22.450 回答
2
Caused by: android.os.NetworkOnMainThreadException

您正在 ui 线程上运行网络相关操作。

HttpResponse httpResponse = httpClient.execute(httpPost);

上述语句必须在 athread或 asynctaskdoInbackground中。

http://developer.android.com/reference/android/os/AsyncTask.html

在 ui 线程上调用 asynctasknew TheTask().execute()

class TheTask extends AsyncTask<Void ,Void, Void>{

        @Override
        protected Void doInBackground(Void... params) {
                   JSONObject jobject =getJSONFromUrl(String url);
            return null;

        }
    }
于 2013-11-14T10:14:58.683 回答
1

您正在主线程中进行网络工作,这就是为什么会出现此错误。对于开发过程,您使用它而不是实时应用程序。

在 setcontentView(layout) 之后,将此代码放在 oncreate 方法中的 Activity 中

if (android.os.Build.VERSION.SDK_INT > 9) {
        StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder()
                .permitAll().build();
        StrictMode.setThreadPolicy(policy);
    }
于 2013-11-14T10:35:04.530 回答
1
Caused by: android.os.NetworkOnMainThreadException

您不能HttpResponse在主线程上使用。您必须使用AsyncTask从 Web 获取 Json。

读这个;

http://developer.android.com/reference/android/os/AsyncTask.html

于 2013-11-14T10:15:31.297 回答
1
public static JSONObject responseForSignin(final String uname,final String pwd) {

         JSONObject jsonResponse = null;
        HttpParams httpParameters = new BasicHttpParams();
        int connectionTimeout = 1000*12;
        int socketTimeout = 1000*13;
        HttpConnectionParams.setConnectionTimeout(httpParameters, connectionTimeout);
        HttpConnectionParams.setSoTimeout(httpParameters, socketTimeout);
        // Create a new HttpClient and Post Header
        HttpClient httpClient = new DefaultHttpClient(httpParameters);
        HttpPost httpPost = new HttpPost("URL");
        httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded");

        try {
            // Add your data

            List<NameValuePair> signinDetails = new ArrayList<NameValuePair>();
            signinDetails.add(new BasicNameValuePair("name", uname));
                         signinDetails.add(new BasicNameValuePair("pwd", pwd));
            httpPost.setEntity(new UrlEncodedFormEntity(signinDetails));
            // Execute HTTP Post Request
            HttpResponse httpResponse = httpClient.execute(httpPost);
            Log.v("Post Status", "Code: "+ httpResponse.getStatusLine().getStatusCode());
            responseCode = httpResponse.getStatusLine().getStatusCode();
                Log.e("responseCode", String.valueOf("response code"+responseCode));
                HttpEntity entity = httpResponse.getEntity();
                Log.e("entity", String.valueOf(entity));
                if (entity != null) {

                    if (entity != null) {

                        String responseBody = EntityUtils.toString(entity);
                        JSONTokener jsonTokener = new JSONTokener(responseBody);
                        jsonResponse = new JSONObject(jsonTokener);
                        JSONObject response = jsonResponse.getJSONObject("response");
                        // Getting String inside response object
                        String status = response.getString("status");
                        String message = response.getString("message");

                    }
                } // if (entity != null) end
        } 

        catch (SocketException seExp) 
        {

        }
        catch (ConnectTimeoutException cteExp) 
        {
        // TODO Auto-generated catch block

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

          catch (UnknownHostException e) {
                // TODO Auto-generated catch block

                e.printStackTrace();
            }
        catch (Exception allExp) {
            // TODO Auto-generated catch block
        }       
        return jsonResponse;
    }

尝试这个

public class RequestLogInFromServer extends AsyncTask<Object, Object, Object>
    {

        private ProgressDialog progressDialog;


        @Override
        protected Object doInBackground(Object... params)
        {

                  try {

                      JSONObject subscriptionResponse = CommonJsonParser.responseForSignin(uname, pwd).getJSONObject("response");

                        if (!(subscriptionResponse.equals(null))||!(subscriptionResponse.equals("")))  {                    


                        }


                    }



                  catch (NullPointerException e) {
                        // TODO Auto-generated catch block


                    }


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


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

            return null;

        }


        @Override
        protected void onPostExecute(Object result) 
        {       
            if(progressDialog!=null){
            progressDialog.dismiss();
            }       

            super.onPostExecute(result);
        }

        @Override
        protected void onPreExecute() {

            progressDialog = ProgressDialog.show(SignInActivity.this, "", "Please wait");
            super.onPreExecute();
        }

    }

使用 AsyncTask.任何服务器请求或需要很长时间的都应该写在后台任务中

于 2013-11-14T10:20:47.730 回答