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程序设计有所帮助。

时间: 2016-06-27

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

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

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

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

javascript 循环读取JSON数据的代码

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

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

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

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

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

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   

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

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

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

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);//为了解决中文

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

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

jquery解析json格式数据的方法(对象、字符串)

本文实例讲述了jquery解析json格式数据的方法.分享给大家供大家参考,具体如下: json数据是我们常用的一种小型的数据实时交换的一个东西,他可以利用jquery或js进行解析,下面我来介绍jquery解析json字符串方法. 一.jQuery解析Json数据格式: 使用这种方法,你必须在Ajax请求中设置参数: dataType: "json" 获取通过回调函数返回的数据并解析得到我们想要的值,看源码: jQuery.ajax({ url: full_url, dataType

Python使用内置json模块解析json格式数据的方法

本文实例讲述了Python使用内置json模块解析json格式数据的方法.分享给大家供大家参考,具体如下: Python中解析json字符串非常简单,直接用内置的json模块就可以,不需要安装额外的模块. 一.json字符串转为python值 json字符串: 复制代码 代码如下: {"userAccount":"54321","date":"2016-12-06 10:26:17","ClickTime"

Android编程解析Json格式数据的方法

本文实例讲述了Android编程解析Json格式数据的方法.分享给大家供大家参考,具体如下: package com.practice.json; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import android.app.Activity; import android.os.Bundle; import android.util.Log; public cla

JavaScript解析JSON格式数据的方法示例

本文实例讲述了JavaScript解析JSON格式数据的方法.分享给大家供大家参考,具体如下: 1.使用JavaScript提供的eval()函数 function JsonText1() { var strJSON = "{'Name':'Kevin','Age':'23'}"; //得到的JSON var obj = eval("(" + strJSON + ")"); //转换后的JSON对象 alert(obj.Name); } 2.使用

Android编程简单解析JSON格式数据的方法示例

本文实例讲述了Android编程简单解析JSON格式数据的方法.分享给大家供大家参考,具体如下: 比起XML,JSON主要优势在于它的体积更小,在网络上传输的时候可以更省流量.但缺点在于,它的语义性较差,显示不如XML直观. JSON格式 : { "name_A" : "value_A","name_B" : "value_B" } 表示: name_A = value_A; name_B = value_B; 我将对下面的J

Mysql使用函数json_extract处理Json类型数据的方法实例

目录 1. 需求概述 2. json_extract简介 2.1 函数简介 2.2 使用方式 2.3 注意事项 3. 实现验证 3.1 建表查询 3.2 查询结果 总结 1. 需求概述 业务开发中通常mysql数据库中某个字段会需要存储json格式字符串,查询的时候有时json数据较大,每次全部取出再去解析查询效率较低,也比较麻烦,则Mysql5.7版本提供提供函数json_extract,可以通过key查询value值,比较方便. 2. json_extract简介 2.1 函数简介 Mysq

jQuery解析json格式数据简单实例

本文实例讲述了jQuery解析json格式数据的方法.分享给大家供大家参考,具体如下: 我用的jquery版本是1.7.2,整合了json数据的解析功能,很早的版本是没有的,我记得那个时候,要么用js的for in来读取json字符串里面的数据,要么加载一个专门用来解析json字符串的JS文件. 例子: <html> <head> <script type="text/javascript" src="jquery-1.7.2.min.js&qu

java读取文件内容,解析Json格式数据方式

目录 java读取文件内容,解析Json格式数据 一.读取txt文件内容(Json格式数据) 二.解析处理Json格式数据 三.结果存入数据库 四.测试 java 读取txt文件中的json数据,进行导出 以下代码可直接运行 java读取文件内容,解析Json格式数据 一.读取txt文件内容(Json格式数据) public static String reader(String filePath) { try { File file = new File(filePath); if (file

Java&nbsp;多层嵌套JSON类型数据全面解析

目录 多层嵌套JSON类型数据解析 以下举例数据结构 解析代码 json解析多层嵌套并转为对应类(List) Json(随便扒的格式,将就看~) 关键依赖 JAVABEAN转JSONObject 多层嵌套JSON类型数据解析 简单来说: “key”:“value” --> 此时value为String“key":0 --> 此时value为int“key”:{“k1”:“v1”} --> 此时value为JSONObject“key”:[v] --> 此时value为JS