0

PHPファイルからデータを取得しようとしています。

これは私のPHPコードです:

$sql=mysql_query("select * from `tracking`");
while($row=mysql_fetch_assoc($sql))
$output[]=$row;
print(json_encode($output));

そして、私は本当にすべてのデータが必要です。これは、データを取得して変換するために使用するコードです。

String result = null;
InputStream is = null;
StringBuilder sb = null;

ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
try {
    HttpClient httpclient = new DefaultHttpClient();
    HttpPost httppost = new HttpPost("http://server/getData.php");
    httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
    HttpResponse response = httpclient.execute(httppost);
    HttpEntity entity = response.getEntity();
    is = entity.getContent();
} catch(Exception e) {
    Log.e("log_tag", "Error in http connection"+e.toString());
}

//convertion de la réponse en String
try {
    //BufferedReader reader = new BufferedReader(new InputStreamReader(is, "iso-8859-1"),8);
    BufferedReader reader = new BufferedReader(new InputStreamReader(is,"UTF-8"),8);
    sb = new StringBuilder();
    sb.append(reader.readLine() + "\n");

    String line="0";
    while ((line = reader.readLine()) != null) {
        sb.append(line + "\n");
        //sb.append(line);
    }

    is.close();
    result=sb.toString();             
} catch(Exception e) {
    Log.e("log_tag", "Error converting result "+e.toString());
}

// Affectation des données
try {
    JSONArray jArray = new JSONArray(result);
    Log.d("jArray", ""+jArray);
    JSONObject json_data= null;

    for(int i=0; i<jArray.length(); i++) {
        p = new Position();
        json_data = jArray.getJSONObject(i);

        Log.d("js", ""+json_data);
        id=json_data.getInt("id");
        lat=(float) json_data.getDouble("lat");
        lon=(float) json_data.getDouble("lon");
        speed=(float) json_data.getDouble("speed");
        alt=json_data.getDouble("alt");
        time=json_data.getString("time");
        date=json_data.getString("date");

        p.setId(id);
        p.setLat(lat);
        p.setLon(lon);
        p.setSpeed(speed);
        p.setAlt(alt);
        p.setDate(date);
        p.setTime(time);

        datasource.createPosition(p);
    }
} catch(JSONException e1) {
    Log.e("JSONEX", ""+e1);
} catch (ParseException e1) {
    e1.printStackTrace();
}

これは実際にはエミュレーターではうまく機能しますが、私のAndroid携帯では機能せず、理由がわかりません。
これがサーバーからのjsonの結果です。

[{"id": "180"、 "lat": "33.894707"、 "lon": "-6.327312"、 "speed": "0.00000"、 "alt": "397"、 "date": "29 / 07/2012 "、" time ":" 23:44 "}]

これは、 http://jsonlint.com/JSONArrayで検証された有効なものです。

4

2 に答える 2

2

JSONの何が問題なのかを見つけました。最初に「?」という文字を見つけました。コードのどこかに追加され、logCatエントリをファイルに保存するまで表示されませんでした。だから私はコード行を追加しました、そしてそれは今うまくいきます。

result = result.substring(1);

将来誰かがWaqasに感謝するのに役立つことを願っています

于 2012-08-02T14:46:10.827 に答える
0

この行を入れてください:

        while(result.charAt(0)!='[')  //or result.charAt(0)!='{'
        {
            result = result.substring(1);
            Log.d("Tag1", "remove 1st char");

        }

後:

        result = sb.toString();

このようになるには:;

        result = sb.toString();

        while(result.charAt(0)!='[')
        {
            result = result.substring(1);
            Log.d("Tag1", "remove 1st char");

        }
于 2016-05-30T09:26:34.503 に答える