Android 数据库连接错误
我是android开发的新手。我使用PHP将android应用程序连接到mysql,并使用“Json”进行编码 解析JSON数据。 但是我在这个代码上有一个错误“JSONArray jArray=null 错误是“mainhome(布局)无法解析,或者不是字段。 java代码如下所示Android 数据库连接错误,android,json,Android,Json,我是android开发的新手。我使用PHP将android应用程序连接到mysql,并使用“Json”进行编码 解析JSON数据。 但是我在这个代码上有一个错误“JSONArray jArray=null 错误是“mainhome(布局)无法解析,或者不是字段。 java代码如下所示 package com.example.bagyourjob; import android.net.ParseException; import android.os.Bundle; import java.
package com.example.bagyourjob;
import android.net.ParseException;
import android.os.Bundle;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import android.R.string;
import android.app.Activity;
import android.content.Intent;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import android.os.Bundle;
public class Test extends Activity implements OnClickListener {
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.mainhome);
JSONArray jArray = null;
String result = null;
StringBuilder sb = null;
InputStream is = null;
ArrayList<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
//http post
try{
HttpClient httpclient = new DefaultHttpClient();
//Why to use 10.0.2.2
HttpPost httppost = new HttpPost("http://10.0.2.2/myfirsttry.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());
}
//convert response to string
try{
BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
sb = new StringBuilder();
sb.append(reader.readLine() + "\n");
String line="0";
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
result=sb.toString();
}catch(Exception e){
Log.e("log_tag", "Error converting result "+e.toString());
}
String name;
try{
jArray = new JSONArray(result);
JSONObject json_data=null;
for(int i=0;i<jArray.length();i++){
json_data = jArray.getJSONObject(i);
String ct_name = json_data.getString("NAME");//here "Name" is the column name in database
}
}
catch(JSONException e1){
Toast.makeText(getBaseContext(), "No Data Found" ,Toast.LENGTH_LONG).show();
} catch (ParseException e1) {
e1.printStackTrace();
}
}
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
}
}
package com.example.bagyourjob;
导入android.net.ParseException;
导入android.os.Bundle;
导入java.io.BufferedReader;
导入java.io.InputStream;
导入java.io.InputStreamReader;
导入java.util.ArrayList;
导入org.apache.http.HttpEntity;
导入org.apache.http.HttpResponse;
导入org.apache.http.NameValuePair;
导入org.apache.http.client.HttpClient;
导入org.apache.http.client.entity.UrlEncodedFormEntity;
导入org.apache.http.client.methods.HttpPost;
导入org.apache.http.impl.client.DefaultHttpClient;
导入org.json.JSONArray;
导入org.json.JSONException;
导入org.json.JSONObject;
导入android.R.string;
导入android.app.Activity;
导入android.content.Intent;
导入android.util.Log;
导入android.view.Menu;
导入android.view.view;
导入android.view.view.OnClickListener;
导入android.widget.Button;
导入android.widget.EditText;
导入android.widget.Toast;
导入android.os.Bundle;
公共类测试扩展了活动实现OnClickListener{
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.mainhome);
JSONArray-jArray=null;
字符串结果=null;
StringBuilder sb=null;
InputStream=null;
ArrayList nameValuePairs=新的ArrayList();
//http post
试一试{
HttpClient HttpClient=新的DefaultHttpClient();
//为什么要使用10.0.2.2
HttpPost HttpPost=新的HttpPost(“http://10.0.2.2/myfirsttry.php");
setEntity(新的UrlEncodedFormEntity(nameValuePairs));
HttpResponse response=httpclient.execute(httppost);
HttpEntity=response.getEntity();
is=entity.getContent();
}捕获(例外e){
e(“Log_标记”,“http连接错误”+e.toString());
}
//将响应转换为字符串
试一试{
BufferedReader reader=新的BufferedReader(新的InputStreamReader(is,“iso-8859-1”),8;
sb=新的StringBuilder();
sb.append(reader.readLine()+“\n”);
字符串行=“0”;
而((line=reader.readLine())!=null){
sb.追加(第+行“\n”);
}
is.close();
结果=sb.toString();
}捕获(例外e){
Log.e(“Log_标记”,“错误转换结果”+e.toString());
}
字符串名;
试一试{
jArray=新的JSONArray(结果);
JSONObject json_data=null;
对于(inti=0;i试试这个.)
只需删除导入android.R.string;
这一行您正在MainActivity中进行网络尝试,这将引发异常并强制关闭您的项目,因此请使用AsyncTask by doInBackground方法执行此操作
学习
到目前为止,我看到您的代码似乎不完整,使用解析过的JSON,但此后从未使用过该数据。您是否在您的布局文件夹中创建了mainhome.xml?是的。我创建了一个简单的布局,名为“mainhome”“。仅用于显示来自MySQL的数据,您正在mainhome中显示数据?解析json数据后未找到代码。@Brendon,请您编写用于向我的应用程序显示数据的代码。首先从代码中删除tat导入android.R.string,然后重试。”