Mysql+Json+Android的组合

这一章,我们重点来介绍服务器Mysql数据库通过PHP将Json数据交给Android来处理,同学们初看一定觉得好多专业术语哦,呵呵,其实,等我讲完,大家应该都能理解,好了,首先我们来看数据库,Mysql数据库,做过网站的同学应该对Mysql数据库不陌生,我们先在Mysql数据库中创建库表跟数据

接下来就要将Mysql的数据暴露给Android了,这里我用了ThinkPHP模板

这里就不讲ThinkPHP的数据库连接之类的了,通过ThinkPHP将数据返回成Json数据

这里先上图吧

好,接下来就是如何将网络Json数据转入Android中了

import java.util.ArrayList;  
  1. import java.util.HashMap;  
  2. import java.util.List;  
  3. import java.util.Map;  
  4.   
  5. import org.json.JSONArray;  
  6. import org.json.JSONObject;  
  7.   
  8. import android.app.Activity;  
  9. import android.os.Bundle;  
  10. import android.widget.ListView;  
  11. import android.widget.SimpleAdapter;  
  12.   
  13. import com.kang.http.HttpConnectionUtil;  
  14. import com.kang.http.HttpConnectionUtil.HttpConnectionCallback;  
  15. import com.kang.http.HttpConnectionUtil.HttpMethod;  
  16.   
  17. public class JsonFromPHPDemo extends Activity  
  18. {  
  19.     private ListView listView;  
  20.     private SimpleAdapter adapter;  
  21.     protected List<Person> persons;  
  22.     private Person person;  
  23.   
  24.     @Override  
  25.     protected void onCreate(Bundle savedInstanceState)  
  26.     {  
  27.         // TODO Auto-generated method stub   
  28.         super.onCreate(savedInstanceState);  
  29.         setContentView(R.layout.xml_handler);  
  30.   
  31.         listView = (ListView) findViewById(R.id.xml_list);  
  32.         try  
  33.         {  
  34.             // 自完义适配方法   
  35.             getAdapter();  
  36.   
  37.         } catch (Exception e)  
  38.         {  
  39.             e.printStackTrace();  
  40.         }  
  41.   
  42.     }  
  43.       
  44.       
  45.     private void getAdapter()  
  46.     {  
  47.         //网址   
  48.         String url = "http://192.168.1.105/PHPDemo/index.php/Index/show";  
  49.         //上节课讲的网络连接方法   
  50.         HttpConnectionUtil connUtil = new HttpConnectionUtil();  
  51.         connUtil.asyncConnect(url, HttpMethod.POST,  
  52.                 new HttpConnectionCallback()  
  53.                 {  
  54.   
  55.                     @Override  
  56.                     public void execute(String response)  
  57.                     {  
  58.   
  59.                         persons = JsonToList(response);  
  60.                         setInAdapter();  
  61.                         listView.setAdapter(adapter);  
  62.                     }  
  63.                 });  
  64.   
  65.     }  
  66.       
  67.       
  68.     protected void setInAdapter()  
  69.     {  
  70.         List<Map<String, String>> lists = new ArrayList<Map<String, String>>();  
  71.         // 将persons中的数据转换到ArrayList<Map<String,String>>中   
  72.         // String>>中,因为SimpleAdapter要用这个类型的数据进行适配   
  73.         Map<String, String> map;  
  74.         for (Person p : persons)  
  75.         {  
  76.             map = new HashMap<String, String>();  
  77.   
  78.             map.put("id", p.getId());  
  79.             map.put("status", p.getStatus());  
  80.             map.put("name", p.getName());  
  81.             map.put("tool", p.getTool());  
  82.             map.put("number", p.getNumber());  
  83.   
  84.             lists.add(map);  
  85.         }  
  86.   
  87.         // HashMap<String, String>中的key   
  88.         String[] from = { "id""status""name""tool""number" };  
  89.         // list_item.xml中对应的控件ID   
  90.         int[] to = { R.id.item_id, R.id.item_status, R.id.item_name,  
  91.                 R.id.item_tool, R.id.item_number };  
  92.   
  93.         adapter = new SimpleAdapter(this, lists, R.layout.handler_list_item,  
  94.                 from, to);  
  95.   
  96.     }  
  97.   
  98.       
  99.     protected List<Person> JsonToList(String response)  
  100.     {  
  101.         List<Person> list = new ArrayList<Person>();  
  102.   
  103.         try  
  104.         {  
  105.             // 将字符串转换为Json数组   
  106.             JSONArray array = new JSONArray(response);  
  107.             // 数组长度   
  108.             int length = array.length();  
  109.             for (int i = 0; i < length; i++)  
  110.             {  
  111.                 // 将每一个数组再转换成Json对象   
  112.                 JSONObject obj = array.getJSONObject(i);  
  113.   
  114.                 person = new Person();  
  115.                 person.setId(obj.getString("id"));  
  116.                 person.setStatus(obj.getString("status"));  
  117.                 person.setName(obj.getString("name"));  
  118.                 person.setTool(obj.getString("tool"));  
  119.                 person.setNumber(obj.getString("number"));  
  120.   
  121.                 list.add(person);  
  122.   
  123.             }  
  124.   
  125.             return list;  
  126.         } catch (Exception e)  
  127.         {  
  128.             e.printStackTrace();  
  129.         }  
  130.         return null;  
  131.     }  
  132.   
  133. }  

这里综合了前面几章的内容,有网络传输数据,有Json处理等,希望同学们认真学习,谢谢。

这里要特别提醒的是因为服务器是架在自己电脑里的,这里的网址是http://192.168.1.105/PHPDemo/index.php/Index/show,千万不能写成localhost,需要写具体的IP地址

要源码的请发邮件地址

阅读更多
个人分类: Android
想对作者说点什么? 我来说一句

Mysql+Json+Android

2011年10月11日 1009KB 下载

组合.rar组合.rar组合.rar

2010年03月29日 16KB 下载

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭