欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android App端與PHP Web端的簡單數(shù)據(jù)交互實現(xiàn)示例

 更新時間:2017年10月23日 15:04:09   作者:uknow  
本篇文章主要介紹了Android App端與PHP Web端的簡單數(shù)據(jù)交互實現(xiàn)示例,詳細(xì)的介紹了交互的代碼,非常具有實用價值,有興趣的可以了解一下

前言

由于學(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)流程

流程說明

  1. 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ù)的添加。
  2. 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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android改變ExpandableListView的indicator圖標(biāo)實現(xià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-03
  • android?ViewPager實現(xiàn)一個無限輪播圖

    android?ViewPager實現(xiàn)一個無限輪播圖

    大家好,本篇文章主要講的是android?ViewPager實現(xiàn)一個無限輪播圖,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • 深入淺析Android接口回調(diào)機(jī)制

    深入淺析Android接口回調(diào)機(jī)制

    在Android中到處可見接口回調(diào)機(jī)制,尤其是UI事件處理方面,本文給大家介紹android接口回調(diào)機(jī)制,涉及到android接口回調(diào)相關(guān)知識,對本文感興趣的朋友可以參考下本篇文章
    2015-11-11
  • Kotlin類對象class初始化與使用

    Kotlin類對象class初始化與使用

    Kotlin 是一種追求簡潔的語言,在類上也下了不少功夫,放棄了很多c++ 中類非常復(fù)雜的概念,其實對于類可以這樣來理解,為了復(fù)用的方便性和完整性,我們把變量和函數(shù)組合在一起,形成了類的概念
    2022-12-12
  • Android?自定義view中根據(jù)狀態(tài)修改drawable圖片

    Android?自定義view中根據(jù)狀態(tài)修改drawable圖片

    這篇文章主要介紹了Android?自定義view中根據(jù)狀態(tài)修改drawable圖片的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • 實例詳解Android解決按鈕重復(fù)點擊問題

    實例詳解Android解決按鈕重復(fù)點擊問題

    在項目中,由于網(wǎng)絡(luò)問題,不知道這個按鈕被點擊了幾次,為了防止這一問題發(fā)生,下面小編寫了一段實例代碼給大家詳解android解決按鈕重復(fù)點擊問題,對android按鈕重復(fù)點擊相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • Android?nonTransitiveRClass資源沖突問題淺析

    Android?nonTransitiveRClass資源沖突問題淺析

    這篇文章主要介紹了Android?nonTransitiveRClass資源沖突問題,別搞錯了,nonTransitiveRClass不能解決資源沖突,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-12-12
  • Flutter實現(xiàn)微信朋友圈功能

    Flutter實現(xiàn)微信朋友圈功能

    這篇文章主要為大家詳細(xì)介紹了Flutter實現(xiàn)微信朋友圈功,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • ListView實現(xiàn)頂部和底部內(nèi)容指示器的方法

    ListView實現(xiàn)頂部和底部內(nèi)容指示器的方法

    這篇文章主要介紹了ListView實現(xiàn)頂部和底部內(nèi)容指示器的方法,需要的朋友可以參考下
    2015-09-09
  • Android Notification的多種用法總結(jié)

    Android Notification的多種用法總結(jié)

    這篇文章主要介紹了Android Notification的多種用法總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2017-06-06

最新評論