日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

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

發(fā)布時(shí)間:2025/3/20 数据库 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android json mysql_Android通过json向MySQL中读写数据的方法详解【读取篇】 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本文實(shí)例講述了Android通過json向MySQL中讀取數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:

首先 要定義幾個(gè)解析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"));//經(jīng)度

}

String location_name=jsonObject.getString("location_name"); //ssid

String wifi_adds = jsonObject.getString("wifi_adds");//wifi地址 具體到多少路多少號(hào)

String area = jsonObject.getString("area");//北京的什么區(qū)

String location_type = jsonObject.getString("location_type");//地點(diǎn)是個(gè)什么類型的,寫字樓??

String ap_free = jsonObject.getString("ap_free");//ap是否免費(fèi)

String category = jsonObject.getString("category");//ap是否免費(fèi)

String password = jsonObject.getString("password");//ap是否免費(fèi)

String capabilities = jsonObject.getString("capabilities");//ap是否免費(fèi)

String user_score = jsonObject.getString("user_score");//ap是否免費(fèi)

String NW_score = jsonObject.getString("NW_score");//ap是否免費(fèi)

}

// tvJson.setText(s);

} catch (JSONException e) {

System.out.println("Jsons parse error !");

e.printStackTrace();

}

}

再定義一個(gè)向MySql發(fā)送http請(qǐng)求的方法connServerForResult,代碼如下:

private String connServerForResult(String strUrl) {

// HttpGet對(duì)象

HttpGet httpRequest = new HttpGet(strUrl);

String strResult = "";

try {

// HttpClient對(duì)象

HttpClient httpClient = new DefaultHttpClient();

// 獲得HttpResponse對(duì)象

HttpResponse httpResponse = httpClient.execute(httpRequest);

if (httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {

// 取得返回的數(shù)據(jù)

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;

}

然后就是在主程序中調(diào)用這兩個(gè)方法:代碼如下

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表中與點(diǎn)(lat,lon)距離小于distance的點(diǎn)打包回來

$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);

?>

還有一點(diǎn)需要注意,就是如果你的終端上的操作系統(tǒng)是android4.0以上的,要添加上那一段代碼,上一篇《Android通過json向MySQL中讀寫數(shù)據(jù)的方法詳解【寫入篇】》有寫,這里略過

如此一來,可以從MySql中成功地將數(shù)據(jù)讀取下來

更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android操作json格式數(shù)據(jù)技巧總結(jié)》、《Android數(shù)據(jù)庫(kù)操作技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android文件操作技巧匯總》、《Android編程開發(fā)之SD卡操作方法匯總》、《Android開發(fā)入門與進(jìn)階教程》、《Android資源操作技巧匯總》、《Android視圖View技巧總結(jié)》及《Android控件用法總結(jié)》

希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。

本文標(biāo)題: Android通過json向MySQL中讀寫數(shù)據(jù)的方法詳解【讀取篇】

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

總結(jié)

以上是生活随笔為你收集整理的android json mysql_Android通过json向MySQL中读写数据的方法详解【读取篇】的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。