Android App端與PHP Web端的簡單數(shù)據(jù)交互實現(xiàn)示例
前言
由于學(xué)??萍剂㈨椀捻椖啃枰獙崿F(xiàn)Android App端與PHP Web端的簡單數(shù)據(jù)交互的實現(xiàn),當(dāng)前場景是Web端使用的是MySql數(shù)據(jù)庫,Apache服務(wù)器和PHP語言編寫的。數(shù)據(jù)交互的簡單理解就是Android能向服務(wù)端進(jìn)行數(shù)據(jù)獲取,同時也能進(jìn)行數(shù)據(jù)提交。
實現(xiàn)流程
流程說明
- Andorid Server端對MySql數(shù)據(jù)庫進(jìn)行簡單的查詢操作,并將查詢數(shù)據(jù)結(jié)果轉(zhuǎn)換為Json格式提供給Andorid利用OKhttp讀取再解析Json展示到APP上;同時Andorid端利用OKhttp提交給Andorid Server端,由Server端對MySql數(shù)據(jù)庫對提交數(shù)據(jù)的添加。
- Apache Server端通過解析PHP源代碼,對MySql數(shù)據(jù)庫的增刪查改顯示在WebSite。
具體實現(xiàn)
Andorid Server
獲取數(shù)據(jù)
get_all_found_items.php
<?php header('Content-Type:text/html;charset=utf-8');/*設(shè)置php編碼為utf-8*/ /* * Following code will list all the items */ // array for JSON response $response = array(); // include db connect class require_once __DIR__ . '/db_connect.php'; // connecting to db $db = new DB_CONNECT(); // get all items from items table $result = mysql_query("SELECT *FROM items WHERE type='1'") or die(mysql_error()); // check for empty result if (mysql_num_rows($result) > 0) { // looping through all results // items node $response["items"] = array(); while ($row = mysql_fetch_array($result)) { // temp user array $items = array(); $items["what"] = $row["what"]; $items["when"] = $row["when"]; $items["where"] = $row["where"]; $items["detail"] = $row["detail"]; $items["posttime"] = $row["posttime"]; $resultcontcat = mysql_query("SELECT *FROM guests") or die(mysql_error()); while ($row1 = mysql_fetch_array($resultcontcat)) { if ($row1["id"] == $row["gid"]){ $items["contact"] = $row1["contact"]; } } // push single items into final response array array_push($response["items"], $items); } // success $response["success"] = 1; // echoing JSON response echo json_encode($response,JSON_UNESCAPED_UNICODE); } else { // no items found $response["success"] = 0; $response["message"] = "No items found"; // echo JSON echo json_encode($response,JSON_UNESCAPED_UNICODE); } ?>
如以上PHP代碼可知通過require_once()函數(shù)包含db_connect.php文件,執(zhí)行數(shù)據(jù)庫配置文件。定義數(shù)組$response接收查詢的數(shù)據(jù)結(jié)果,通過判斷不同的情況賦值$response[“success”],并返回到Web頁面顯示
PHP文件執(zhí)行結(jié)果
JSON
{ "items": [ { "what": "手表", "when": "2017-10-21 00:00:00", "where": "北區(qū)宿舍樓#504", "detail": "白色的手表,XX品牌", "posttime": "2017-10-21 13:03:09", "contact": "138123456" }, { "what": "手機(jī)", "when": "2017-10-04 00:00:00", "where": "北區(qū)商店#111", "detail": "iphone6s,土豪金", "posttime": "2017-10-21 13:03:46", "contact": "137123456" }, { "what": "電腦", "when": "2017-10-21 14:39:54", "where": "圖書館#203", "detail": "聯(lián)想品牌筆記本", "posttime": "2017-10-21 17:08:14", "contact": "5670001" }, { "what": "細(xì)說PHP", "when": "2017-09-21 13:03:46", "where": "南館#403", "detail": "黑色封面,第二版《細(xì)說PHP》", "posttime": "2017-10-21 17:36:53", "contact": "63513641" } ], "success": 1 }
提交數(shù)據(jù)
create_found_items.php
<?php header('Content-Type:text/html;charset=utf-8');/*設(shè)置php編碼為utf-8*/ /* * Following code will create a new product row * All product details are read from HTTP GET Request */ // array for JSON response $response = array(); // check for required fields if (isset($_GET['what']) && isset($_GET['when']) && isset($_GET['where']) && isset($_GET['detail'])&& isset($_GET['contact'])) { $what = $_GET['what']; $when = $_GET['when']; $where = $_GET['where']; $detail = $_GET['detail']; $contact = $_GET['contact']; // include db connect class require_once __DIR__ . '/db_connect.php'; // connecting to db $db = new DB_CONNECT(); // mysql inserting a new row $result2 = mysql_query("INSERT INTO guests(contact) VALUES('$contact')"); $gidresult = mysql_query("SELECT id FROM `guests` WHERE contact='$contact'"); while ($row = mysql_fetch_array($gidresult)) { $gid=$row['id']; } $result1 = mysql_query("INSERT INTO items(`what`, `when`, `where`, `type` ,`gid`, `detail`) VALUES('$what', '$when', '$where', '1', '$gid', '$detail')"); // check if row inserted or not if ($result1 && $result2) { // successfully inserted into database $response["success"] = 1; $response["message"] = "Items successfully created."; // echoing JSON response echo json_encode($response,JSON_UNESCAPED_UNICODE); } else { // failed to insert row $response["success"] = 0; $response["message"] = "Oops! An error occurred."; // echoing JSON response echo json_encode($response,JSON_UNESCAPED_UNICODE); } } else { // required field is missing $response["success"] = 0; $response["message"] = "Required field(s) is missing"; // echoing JSON response echo json_encode($response,JSON_UNESCAPED_UNICODE); } ?>
判斷GET請求的參數(shù)是否都存在,把獲取的GET請求參數(shù)作為數(shù)據(jù)INSERT TO MySQL數(shù)據(jù)庫。判斷INSERT執(zhí)行過程賦值$response[“success”]對應(yīng)相應(yīng)的$response[“message”],顯示在Web頁面。
執(zhí)行結(jié)果
Andorid
獲取數(shù)據(jù)
核心代碼 queryLosts()函數(shù)
private void queryLosts() { losts.clear(); new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub OkHttpClient okHttpClient = new OkHttpClient(); String url = "http://webSite/androidapi/get_all_lost_items.php"; Request request = new Request.Builder() .url(url) .build(); Call call = okHttpClient.newCall(request); try { Response response = call.execute(); String res = response.body().string(); if (res != null && !res.trim().equals("")){ JSONObject jsonObject = new JSONObject(res); if (jsonObject.getInt("success") == 1){ JSONArray jsonArray = jsonObject.getJSONArray("items"); for (int i = jsonArray.length() - 1;i >= 0;i--){ JSONObject item = jsonArray.getJSONObject(i); String what = null; try { what = item.getString("what"); }catch (Exception e){ } String when = null; try{ when = item.getString("when"); }catch (Exception e){ } String where = null; try{ where = item.getString("where"); }catch (Exception e){ } String detail = null; try { detail = item.getString("detail"); }catch (Exception e){ } String contact = null; try { contact = item.getString("contact"); }catch (Exception e){ } Lost lost = new Lost(); lost.setTitle(what); String des = "地點:" + (where == null?"":where) +" "+"時間:" + (when == null?"":when)+"\r" + " "+"描述:" + (detail == null?"":detail); lost.setDescribe(des); lost.setPhone(contact == null?"":contact); losts.add(lost); } } } } catch (Exception e) { e.printStackTrace(); showErrorView(0); } if (losts == null || losts.size() == 0) { handler.sendEmptyMessage(1); return; } if (losts.size() > 0){ handler.sendEmptyMessage(2); } } }).start();
利用Android網(wǎng)絡(luò)框架OKhttp,OKhttp一個處理網(wǎng)絡(luò)請求的開源項目,是安卓端最火熱的輕量級框架.請求接口url地址,獲取Json數(shù)據(jù)利用JSONObject對Json數(shù)據(jù)進(jìn)行解析。
提交數(shù)據(jù)
核心代碼 addLost()函數(shù)
public Handler handler = new Handler(){ public void handleMessage(android.os.Message msg) { switch(msg.what){ case 1: Toast.makeText(this,"提交成功",Toast.LENGTH_LONG).show(); break; case 2: Toast.makeText(this,"提交失敗",Toast.LENGTH_LONG).show(); break; } } }; private void addLost(){ OkHttpClient okHttpClient = new OkHttpClient(); String url ="http://website/androidapi/create_lost_items.php?what="+title+"&when="+time+"&where="+place+"&detail="+describe+"&contact="+photo+""; Request request = new Request.Builder() .url(url) .build(); try{ Response response = okHttpClient.newCall(request).execute(); res = response.body().string(); handler.sendEmptyMessage(1); }catch (Exception e) { e.printStackTrace(); handler.sendEmptyMessage(2); } }
同樣利用Okhttp,GET方式提交參數(shù),try-catch獲取異常,通過返回值給出一定的提交結(jié)果提示。
代碼測試
數(shù)據(jù)同步
Web端
Andorid端
數(shù)據(jù)提交
提交結(jié)果
結(jié)語
以上過程基本實現(xiàn),項目基本上可以交差了。這個項目PHP部分主要是由自己在弄,也是邊學(xué)邊做。Android方面是另外一個同學(xué)主要負(fù)責(zé),期間也求助過我實習(xí)時結(jié)交的朋友幫助。感謝所有付出與幫助的人。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android md5加密與php md5加密一致詳解
- Android上傳文件到Web服務(wù)器 PHP接收文件
- Android通過PHP服務(wù)器實現(xiàn)登錄功能
- PHP簡單判斷iPhone、iPad、Android及PC設(shè)備的方法
- php、java、android、ios通用的3des方法(推薦)
- 基于PHP后臺的Android新聞瀏覽客戶端
- php生成Android客戶端掃描可登錄的二維碼
- Android異步上傳圖片到PHP服務(wù)器
- 使用PHP開發(fā)Android應(yīng)用程序技術(shù)介紹
- Android訪問php取回json數(shù)據(jù)實例
- android+json+php+mysql實現(xiàn)用戶反饋功能方法解析
- Android和PHP MYSQL交互開發(fā)實例
相關(guān)文章
Android改變ExpandableListView的indicator圖標(biāo)實現(xiàn)方法
這篇文章主要介紹了Android改變ExpandableListView的indicator圖標(biāo)實現(xiàn)方法,結(jié)合實例形式分析了改變ExpandableListView的indicator圖標(biāo)相關(guān)步驟與實現(xiàn)技巧,涉及Android配置文件的修改,需要的朋友可以參考下2016-03-03android?ViewPager實現(xiàn)一個無限輪播圖
大家好,本篇文章主要講的是android?ViewPager實現(xiàn)一個無限輪播圖,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-02-02Android?自定義view中根據(jù)狀態(tài)修改drawable圖片
這篇文章主要介紹了Android?自定義view中根據(jù)狀態(tài)修改drawable圖片的相關(guān)資料,需要的朋友可以參考下2023-07-07Android?nonTransitiveRClass資源沖突問題淺析
這篇文章主要介紹了Android?nonTransitiveRClass資源沖突問題,別搞錯了,nonTransitiveRClass不能解決資源沖突,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-12-12ListView實現(xiàn)頂部和底部內(nèi)容指示器的方法
這篇文章主要介紹了ListView實現(xiàn)頂部和底部內(nèi)容指示器的方法,需要的朋友可以參考下2015-09-09Android Notification的多種用法總結(jié)
這篇文章主要介紹了Android Notification的多種用法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-06-06