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 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(thislists, 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 0length; 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地址

要源码的请发邮件地址

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值