簡體   English   中英

Galaxy S3 JSON錯誤

[英]Galaxy S3 JSON Error

我正在開發一個小應用程序,該應用程序獲取當前的地理坐標並返回帶有json對象的相關地址。 問題出在這里:如果我在Samsung Galaxy S上運行應用程序,則可以完美運行,但是,如果我在Galaxy S3上運行該應用程序,則會發生運行時錯誤,例如,它將獲取當前位置坐標,但無法檢索json對象。 代碼如下:

package com.demobasar;

import android.content.Context;
import android.location.Criteria;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Handler;
import android.support.v7.app.ActionBarActivity;

import android.os.Bundle;

import android.widget.TextView;
import android.widget.Toast;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;

import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONException;
import org.json.JSONObject;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;

public class MainActivity extends ActionBarActivity implements LocationListener {
    TextView longT, latT, ulke, sehir, ilce, sokak, mahalle;
    private LocationManager locationManager;
    private String provider;
    Location location;
    double lat, lng;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        longT = (TextView) findViewById(R.id.longT);
        latT = (TextView) findViewById(R.id.lat);
        ulke = (TextView) findViewById(R.id.ulke);
        sehir = (TextView) findViewById(R.id.sehir);
        ilce = (TextView) findViewById(R.id.ilce);
        sokak = (TextView) findViewById(R.id.sokak);
        mahalle =(TextView) findViewById(R.id.mahalle);

        locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);

        Criteria criteria = new Criteria();
        provider = locationManager.getBestProvider(criteria, false);
        location = locationManager.getLastKnownLocation(provider);

        if (location != null) {
            onLocationChanged(location);
        } else {
            longT.setText("Location not available");
            latT.setText("Location not available");
        }
        final Handler handler = new Handler();
        handler.postDelayed(new Runnable() {
            @Override
            public void run() {

                    try {
                        ulke.setText(getJson("http://maps.basarsoft.com.tr/yb5.ashx?f=rg&x=" + lng + "&y=" +lat).getString("Order0"));
                        sehir.setText(getJson("http://maps.basarsoft.com.tr/yb5.ashx?f=rg&x=" + lng + "&y=" +lat).getString("Order1"));
                        ilce.setText(getJson("http://maps.basarsoft.com.tr/yb5.ashx?f=rg&x=" + lng + "&y=" +lat).getString("Order8"));
                        mahalle.setText(getJson("http://maps.basarsoft.com.tr/yb5.ashx?f=rg&x=" + lng + "&y=" +lat).getString("Order9"));
                        sokak.setText(getJson("http://maps.basarsoft.com.tr/yb5.ashx?f=rg&x=" + lng + "&y=" +lat).getString("Street"));
                    } catch (JSONException e) {
                         e.printStackTrace();

                    }

            }
        }, 10000);

    }
    @Override
    protected void onResume() {
        super.onResume();
        locationManager.requestLocationUpdates(provider, 400, 1, this);
    }
    @Override
    protected void onPause() {
        super.onPause();
        locationManager.removeUpdates(this);
    }
    @Override
    public void onLocationChanged(Location location) {
        lat = location.getLatitude();
        lng = location.getLongitude();
        longT.setText("" + lng);
        latT.setText("" + lat);
    }
    @Override
    public void onStatusChanged(String provider, int status, Bundle extras) {
        // TODO Auto-generated method stub
    }

    @Override
    public void onProviderEnabled(String provider) {
        Toast.makeText(this, "Enabled new provider " + provider,
                Toast.LENGTH_SHORT).show();
    }

    @Override
    public void onProviderDisabled(String provider) {
        Toast.makeText(this, "Disabled provider " + provider,
                Toast.LENGTH_SHORT).show();
    }
    public static JSONObject getJson(String url){

        InputStream is = null;
        String result = "";
        JSONObject jsonObject = null;

        try {
            HttpClient httpclient = new DefaultHttpClient();
            HttpGet httppost = new HttpGet(url);
            HttpResponse response = httpclient.execute(httppost);
            HttpEntity entity = response.getEntity();
            is = entity.getContent();
        } catch(Exception e) {
            return null;
        }
        try {
            BufferedReader reader = new BufferedReader(new InputStreamReader(is,"utf-8"),8);
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                sb.append(line + "\n");
            }
            is.close();
            result = sb.toString();
        } catch(Exception e) {
            return null;
        }
        try {
            jsonObject = new JSONObject(result);
        } catch(JSONException e) {
            return null;
        }
        return jsonObject;
    }
}

而android清單如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.demobasar"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="10"
        android:targetSdkVersion="19" />
        <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.INTERACT_ACROSS_USERS_FULL"/>


    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.demobasar.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

最后是LogCat:

01-19 22:01:14.689  23948-23948/com.demobasar E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.NullPointerException
            at com.demobasar.MainActivity$1.run(MainActivity.java:68)
            at android.os.Handler.handleCallback(Handler.java:730)
            at android.os.Handler.dispatchMessage(Handler.java:92)
            at android.os.Looper.loop(Looper.java:176)
            at android.app.ActivityThread.main(ActivityThread.java:5419)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:525)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1046)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:862)
            at dalvik.system.NativeStart.main(Native Method)

由於API 3.0如果在GUI線程上進行任何網絡操作,Android都會引發NetworkOnMainThreadException,這就是您在處理程序中所做的事情(它是在GUI線程上創建的,因此它在GUI線程上運行)。 Galaxy S隨附Android 2.x,不會引發此異常。

NetworkOnMainThreadException可能在您的logcat中更深的地方

通常的解決方案是將網絡操作放入AsyncTask

供參考http://www.androiddesignpatterns.com/2012/06/app-force-close-honeycomb-ics.html

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM