Android通过json向MySQL中读写数据的方法详解【读取篇】

本文实例讲述了Android通过json向MySQL中读取数据的方法。分享给大家供大家参考,具体如下:

首先 要定义几个解析json的方法parseJsonMulti,代码如下:

private void parseJsonMulti(String strResult) {
  try {
   Log.v("strResult11","strResult11="+strResult);
    int index=strResult.indexOf("[");
    if(index>0)
     strResult=strResult.substring(index, strResult.length());
    Log.v("strResult22","strResult22="+strResult);
    wifiMapData = new JSONArray(strResult);
    Log.v("wifiMapDataLength",""+wifiMapData.length());
   for(int i = 0; i < wifiMapData.length() ; i++){///基站信息处理
    ///MapData m=new MapData(1, dLat[5], dLong[5], 10, 20, 300, 500, 105, "教1", 1, 1, 4);
    JSONObject jsonObject = wifiMapData.getJSONObject(i);
     int id=Integer.parseInt(jsonObject.getString("id")); //id
    // if(jsonObject.isNull("mac_address")) mac_address="";
     String mac_address = jsonObject.getString("mac_address");//wifi的mac地址
     String wifi_name=jsonObject.getString("wifi_name"); //ssid
     if(!jsonObject.isNull("lat")&&!jsonObject.isNull("lon")){
     lat= Double.valueOf(jsonObject.getString("lat"));//纬度
     lon=Double.valueOf(jsonObject.getString("lon"));//经度
     }
     String location_name=jsonObject.getString("location_name"); //ssid
     String wifi_adds = jsonObject.getString("wifi_adds");//wifi地址 具体到多少路多少号
     String area = jsonObject.getString("area");//北京的什么区
     String location_type = jsonObject.getString("location_type");//地点是个什么类型的,写字楼??
     String ap_free = jsonObject.getString("ap_free");//ap是否免费
     String category = jsonObject.getString("category");//ap是否免费
     String password = jsonObject.getString("password");//ap是否免费
     String capabilities = jsonObject.getString("capabilities");//ap是否免费
     String user_score = jsonObject.getString("user_score");//ap是否免费
     String NW_score = jsonObject.getString("NW_score");//ap是否免费
   }
   // tvJson.setText(s);
  } catch (JSONException e) {
   System.out.println("Jsons parse error !");
   e.printStackTrace();
  }
}

再定义一个向MySql发送http请求的方法connServerForResult,代码如下:

private String connServerForResult(String strUrl) {
  // HttpGet对象
  HttpGet httpRequest = new HttpGet(strUrl);
  String strResult = "";
  try {
   // HttpClient对象
   HttpClient httpClient = new DefaultHttpClient();
   // 获得HttpResponse对象
   HttpResponse httpResponse = httpClient.execute(httpRequest);
   if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
    // 取得返回的数据
    strResult = EntityUtils.toString(httpResponse.getEntity());
   }
  } catch (ClientProtocolException e) {
   Toast.makeText(Setting.this,
     "protocol error", Toast.LENGTH_SHORT).show();
   e.printStackTrace();
  } catch (IOException e) {
   Toast.makeText(Setting.this,
     "IO error", Toast.LENGTH_SHORT).show();
   e.printStackTrace();
  }
  return strResult;
}

然后就是在主程序中调用这两个方法:代码如下

String strUrl1 = "http://192.168.1.2/call_for_wifiMapData.php";
//获得返回的Json字符串
String strResult1 = connServerForResult(strUrl1);
Log.v("strResult1",strResult1);
parseJsonMulti(strResult1);

只有几句话而已,php同样要替换成你自己的文件路径,

php代码如下:

<?php
  $jsonArrayString = $_POST["jsonArrayString"];
  $jsonString = $_POST["jsonString"];
  $objArray=json_decode($jsonArrayString,true);
  $obj=json_decode($jsonString);
  $lon = (float)$obj->lon;
  $lat = (float)$obj->lat;
  $distance=(float)$obj->distance;
  if($lat==null||$lat==0){
  $lat=39.990132;
  $lon=116.332224;
  $distance=100000;
  }
  ////将cell表中与点(lat,lon)距离小于distance的点打包回来
  $con = mysql_connect("localhost","root",null);
  if (!$con) {
    die('Could not connect:'.mysql_error() );
  }
  mysql_select_db("a0722152915", $con);
  mysql_query("set names 'utf8'");
  $sqlfind = "select * from `wifi`";
  $resultFind = mysql_query($sqlfind, $con);
  $length=mysql_num_rows($resultFind);
  $arr=array();
  $j=0;
  for($i=0;$i<$length;$i++)
  {
    $row = mysql_fetch_array($resultFind);
    $arr[$j]['id'] = $row['id'];
    $arr[$j]['mac_address']=$row['mac_address'];
    $arr[$j]['wifi_name']=$row['wifi_name'];
    $arr[$j]['lat']=$row['gps_lat'];
    $arr[$j]['lon']=$row['gps_lon'];
    $arr[$j]['location_name']=$row['location_name'];
    $arr[$j]['wifi_adds']=$row['wifi_adds'];
    $arr[$j]['area']=$row['area'];
    $arr[$j]['location_type']=$row['location_type'];
    $arr[$j]['ap_free']=$row['ap_free'];
    $arr[$j]['category']=$row['category'];
    $arr[$j]['password']=$row['password'];
    $arr[$j]['capabilities']=$row['capabilities'];
    $arr[$j]['user_score']=$row['user_score'];
    $arr[$j]['NW_score']=$row['NW_score'];
    $j++;
  }
  //print_r($arr);\
  echo json_encode($arr);
?>

还有一点需要注意,就是如果你的终端上的操作系统是android4.0以上的,要添加上那一段代码,上一篇《Android通过json向MySQL中读写数据的方法详解【写入篇】》有写,这里略过

如此一来,可以从MySql中成功地将数据读取下来

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • js读取并解析JSON类型数据的方法

    本文实例讲述了js读取并解析JSON类型数据的方法.分享给大家供大家参考,具体如下: 一.什么是JSON? JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式,同时,JSON是 JavaScript 原生格式. 非常适合于服务器与 JavaScript 的交互 二.为什么使用JSON而不是XML 他们都是这样说的:尽管有许多宣传关于 XML 如何拥有跨平台,跨语言的优势,然而,除非应用于 Web Ser

  • PHP读取mssql json数据中文乱码的解决办法

    PHP及网页使用UTF-8编码,数据库是sql server2008,使用默认编码(936,即GBK编码) 当读取数据库数据时,使用php自带的json_encode()返回到前端,结果中文不显示. 解决办法如下: 这样,sql server 2008中的中文就可以在网页正常显示了. 如果要将中文正常插入到sql server 2008中,还要加入一条代码:$query = iconv("utf-8", "gbk//ignore", $query);//为了解决中文

  • JSON 数据格式详解

    基础结构 JSON建构于两种结构: 1. "名称/值"对的集合(A collection of name/value pairs).不同的语言中,它被理解为对象(object),记录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array). 2. 值的有序列表(An ordered list of values).在大部分语言中,它被理解为数组(array

  • python读取json文件并将数据插入到mongodb的方法

    本文实例讲述了python读取json文件并将数据插入到mongodb的方法.分享给大家供大家参考.具体实现方法如下: #coding=utf-8 import sunburnt import urllib from pymongo import Connection from bson.objectid import ObjectId import logging from datetime import datetime import json from time import mktime

  • Android App中读取XML与JSON格式数据的基本方法示例

    XML 假如有这样一个XML格式的数据: <?xml version="1.0" encoding="utf-8"?> <resources> <customer name="luopeng" age="21" gender="1" emial="dylankeepmoving@163.com"/> <customer name="dy

  • 使用MSScriptControl 在 C# 中读取json数据的方法

    C#中已经有JavaScriptSerializer类可以将json数据给反序列化为对象 /// <summary> /// JSON文本转对象,泛型方法 /// </summary> /// <typeparam name="T">类型</typeparam> /// <param name="jsonText">JSON文本</param> /// <returns>指定类型的对

  • asp实现读取数据库输出json代码

    复制代码 代码如下: Function GetTable(Table,Where,Order,OrderSort,curpage, pagesize,MiniJson) 'Author : nigou '使用方法 : Response.Write GetTable(Table表名,Where条件,Order主键(必须),OrderSort(asc,desc),curpage当前页, pagesize每页条数,MiniJson是否输出为miniUI格式) '     dim i, j ,rs   

  • 如何使用ajax读取Json中的数据

    本文给大家分享一下,如何使用ajax读取Json中的数据. 一.基础知识 什么是json? JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据交换格式 JSON 独立于语言 * JSON 具有自我描述性,更易理解 JSON 使用 JavaScript 语法来描述数据对象,但是 JSON 仍然独立于语言和平台.JSON 解析器和 JSON 库支持许多不同的编程语言. JSON - 转换为 JavaScript 对

  • litjson读取数据示例

    1.下载并应用LitJson,DLL文件 2.建两个类: 复制代码 代码如下: public class JsonData    {        public string result { get; set; }        public List<GameData> info { get; set; }    } public GameData()        { }        #region Model        private int _id;        privat

  • js读取json文件片段中的数据实例

    在html中利用js读取动态网站从服务器端返回的数据进行显示 1.js.html 页面 需要引入 执行jquery的js文件 <HTML> <HEAD> <META name=Generator content=EditPlus> <META name=Author content=""> <META name=Keywords content=""> <META name=Description c

  • javascript 循环读取JSON数据的代码

    服务端后台返回到客户端的JSON格式字符串: var str = '[{"uname":"王强","day":"2010/06/17"},{"uname":"王海云","day":"2010/06/11"}]'; 我们把它转换成JSON对象:var jsonList=eval("("+str+")");这时候

  • Android中Json数据读取与创建的方法

    首先介绍下JSON的定义,JSON是JavaScript Object Notation的缩写. 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换.JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为. JSON的结构: (1) Name/Value Pairs(无序的):类似所熟知的Keyed list. Hash table.Disctiona

随机推荐