android json mysql_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代码如下:

$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

{

$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通过json向MySQL中读写数据的方法详解【读取篇】

本文地址: http://www.cppcns.com/ruanjian/android/155302.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值