我对JSON在爪哇的 MySQL 的反应有疑问
try {
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://parkfinder.zxq.net/default.php");
httppost.setEntity(new UrlEncodedFormEntity(coordinatesToSend));
HttpResponse response = httpclient.execute(httppost);
Log.d("HTTP Client", "HTTP Request made");
HttpEntity entity = response.getEntity();
inputStream = entity.getContent();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream,
"iso-8859-1"), 8);
sb = new StringBuilder();
sb.append(bufferedReader.readLine() + "
");
String line = "0";
while ((line = bufferedReader.readLine()) != null) {
sb.append(line + "
");
}
inputStream.close();
bufferedReader.close();
result = sb.toString();
Log.d("RESULT", result);
JSONObject json_data = new JSONObject(result);
Log.d("JSON","Finished");
JSONArray nameArray = json_data.names();
JSONArray valArray = json_data.toJSONArray(nameArray);
for (int i = 0; i < nameArray.length(); i++) {
Log.d("NAMES", nameArray.getString(i));
}
for (int i = 0; i < nameArray.length(); i++) {
Log.d("NAMES", nameArray.getString(i));
}
} catch (Exception e) {
// TODO: handle exception
}
This is the MySQL Accessing and retreiving info, and parsing it afterwars. the
Log.d("RESULT", result);
设置正确结果的行数 :
2[{"longtitude":"32.32","latitude":"33.12"}]
然而,
Log.d("JSON","Finished");
Never gets called, so the problem seems to be on this line
JSONObject json_data = new JSONObject(result);
本文取自一个教程, 我在互联网上和这个网站上看到许多例子, 有一些指出的错误, 但不是这个错误。
Any help would be great! Thanks
EDIT: The printStackTrace() output:
0`5-14 21:38:18.639: WARN/System.err(665): org.json.JSONException: A JSONObject text must begin with { at character 1 of 2[{"longtitude":"32.32","latitude":"33.12"}]`
php 代码 :
<?php
$host = "localhost";
$user = "**MASKED**";
$password = "**MASKED**";
$database = "parkfinder_zxq_coordinates";
$connection = mysql_connect($host, $user, $password) or die("couldn t connect to server");
$db = mysql_select_db($database, $connection) or die("couldn t select database.");
//$request_parked = $_REQUEST[ parked ];
$request_long = $_REQUEST[ longtitude ];
$request_lat = $_REQUEST[ latitude ];
//if ($request_parked == FIND ) {
$q = mysql_query("SELECT * FROM Coordinates");
while ($e = mysql_fetch_assoc($q))
$output[] = $e;
print (json_encode($output));
//}
mysql_close();
?>