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

 更新时间:2016年06月30日 16:19:22   作者:天鹰之眼  
这篇文章主要介绍了Android通过json向MySQL中读写数据的方法,涉及Android解析json以及与php交互读取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程序设计有所帮助。

相关文章

  • Android实现断点下载的方法

    Android实现断点下载的方法

    这篇文章主要为大家详细介绍了Android实现断点下载的方法,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • Android TextView设置背景色与边框的方法详解

    Android TextView设置背景色与边框的方法详解

    本篇文章是对Android中TextView设置背景色与边框的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Android实现布局全屏

    Android实现布局全屏

    这篇文章主要为大家详细介绍了Android实现布局全屏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • Android中的Looper对象详细介绍

    Android中的Looper对象详细介绍

    这篇文章主要介绍了Android中的Looper对象,需要的朋友可以参考下
    2014-02-02
  • android编程获取和设置系统铃声和音量大小的方法

    android编程获取和设置系统铃声和音量大小的方法

    这篇文章主要介绍了android编程获取和设置系统铃声和音量大小的方法,实例分析了Android针对音频的相关操作技巧,需要的朋友可以参考下
    2017-06-06
  • Flexbox+ReclyclerView实现流式布局

    Flexbox+ReclyclerView实现流式布局

    这篇文章主要为大家详细介绍了Flexbox+ReclyclerView实现流式布局,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • Android开发之android_gps定位服务简单实现

    Android开发之android_gps定位服务简单实现

    这篇文章主要介绍了Android开发之android_gps定位服务简单实现 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-04-04
  • Android 动态改变布局实例详解

    Android 动态改变布局实例详解

    这篇文章主要介绍了Android 动态改变布局实例详解的相关资料,这里举例说明如何实现动态改变布局的例子,帮助大家学习理解,需要的朋友可以参考下
    2016-11-11
  • Flutter给控件实现钻石般的微光特效

    Flutter给控件实现钻石般的微光特效

    这篇文章主要给大家介绍了关于Flutter给控件实现钻石般的微光特效的相关资料,实现的效果非常不错,非常适合大家做开发的时候参考,需要的朋友可以参考下
    2021-08-08
  • Flutter 设置全局字体的实现

    Flutter 设置全局字体的实现

    本文主要介绍了Flutter 设置全局字体的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02

最新评论