【发布时间】:2014-02-02 04:35:47
【问题描述】:
我正在尝试根据用户提供的一些特定参数从我的数据库中检索学校列表。我有很多代码,但我找不到我的错误,需要一些帮助。我花了 6 个多小时研究并试图解决这个问题。我似乎无法修复它。我将不胜感激。
这是一个连接到 MySQL 数据库的安卓应用程序。
这是我在单击按钮时启动搜索的代码:
btnGetSchool.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String city = inputCity.getText().toString();
String school = inputSchoolName.getText().toString();
String state = chooseState.getSelectedItem().toString();
UserFunctions userFunction = new UserFunctions();
JSONObject json = userFunction.getSchool(school, state, city);
try {
schoolText.setText(json.getString(""));
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
这是我的 UserFunctions.java 代码:
public JSONObject getSchool(String school, String state, String city) {
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("school", school));
params.add(new BasicNameValuePair("state", state));
params.add(new BasicNameValuePair("city", city));
JSONObject json = jsonParser.getJSONFromUrl(getSchoolURL, params);
return json;
}
我的 JSON 解析器:
package com.fbla.sap;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.util.List;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONException;
import org.json.JSONObject;
import android.util.Log;
public class JSONParser {
static InputStream is = null;
static JSONObject jObj = null;
static String json = "";
// constructor
public JSONParser() {
}
public JSONObject getJSONFromUrl(String url, List<NameValuePair> params) {
// Making HTTP request
try {
// defaultHttpClient
DefaultHttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(url);
httpPost.setEntity(new UrlEncodedFormEntity(params));
HttpResponse httpResponse = httpClient.execute(httpPost);
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();
Log.e("JSON", json);
} 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;
}
}
最后,我的 PHP 代码用于实际搜索学校。我觉得这个错误可能源于这里,因为我对 PHP 很陌生并且不完全理解它:
public function schoolSearch($school, $state, $city){
$schsearch=mysql_query("
SELECT `sch_name`, `sch_id`,sch_state`,`sch_city`
FROM `schools`
WHERE (`sch_name`=$school) AND (`sch_state`=$state) AND (`sch_city`=$city)
");
/**$searchresult=array();-
while($schresult=mysql_fetch_array($schsearch)) {
array_push($searchresult, $schresult['sch_id']."=>".$schresult['sch_name']);
}**/
return mysql_fetch_array($schresult);
/**if (count($searchresult) > 0) {
return $searchresult;
} else {
return false;
}**/
}
总结一下,我将添加我的错误:
02-01 23:32:03.260: E/AndroidRuntime(12803): FATAL EXCEPTION: main
02-01 23:32:03.260: E/AndroidRuntime(12803): java.lang.NullPointerException
02-01 23:32:03.260: E/AndroidRuntime(12803): at com.fbla.sap.CreateAccFragment$2.onClick(CreateAccFragment.java:148)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.view.View.performClick(View.java:4475)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.view.View$PerformClick.run(View.java:18784)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.os.Handler.handleCallback(Handler.java:730)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.os.Handler.dispatchMessage(Handler.java:92)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.os.Looper.loop(Looper.java:137)
02-01 23:32:03.260: E/AndroidRuntime(12803): at android.app.ActivityThread.main(ActivityThread.java:5450)
02-01 23:32:03.260: E/AndroidRuntime(12803): at java.lang.reflect.Method.invokeNative(Native Method)
02-01 23:32:03.260: E/AndroidRuntime(12803): at java.lang.reflect.Method.invoke(Method.java:525)
02-01 23:32:03.260: E/AndroidRuntime(12803): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1187)
02-01 23:32:03.260: E/AndroidRuntime(12803): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003)
02-01 23:32:03.260: E/AndroidRuntime(12803): at dalvik.system.NativeStart.main(Native Method)
【问题讨论】:
-
在您的 SQL 查询中缺少
sch_state中的开头反引号。 -
这个问题有很多问题。你已经向我们倾倒了大量的代码,它甚至不完整。您期望我们发现未指定的错误,而无需您可能进行的任何调试。你必须缩小问题的范围。从 PHP 端开始,调试它并确保它正常工作。然后向上移动。学习一些适当的调试技巧。
-
PHP 代码片段给出的任何异常都可能会提供更多有用的信息。我建议从 PHP 块开始分解问题。
-
看到问题是,我不知道我到底在做什么。我已经进行了数小时的调试,但无济于事。我直接进入了这个,所以我不一定知道如何解决这些问题。
标签: php android mysql database json