返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >Android App端与PHP Web端的简单数据交互的示例分析
  • 212
分享到

Android App端与PHP Web端的简单数据交互的示例分析

androidphp 2023-05-30 19:05:35 212人浏览 独家记忆
摘要

小编给大家分享一下Android App端与PHP WEB端的简单数据交互的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!实现流程流程说明Andorid

小编给大家分享一下Android App端与PHP WEB端的简单数据交互的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

实现流程

Android App端与PHP Web端的简单数据交互的示例分析

流程说明

  1. Andorid Server端对MySql数据库进行简单的查询操作,并将查询数据结果转换为JSON格式提供给Andorid利用OKHttp读取再解析json展示到APP上;同时Andorid端利用OKhttp提交给Andorid Server端,由Server端对Mysql数据库对提交数据的添加。

  2. Apache Server端通过解析php源代码,对mysql数据库的增删查改显示在WebSite。

具体实现

Andorid Server

获取数据

get_all_found_items.php

<?php header('Content-Type:text/html;charset=utf-8');   // 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()函数包含db_connect.php文件,执行数据库配置文件。定义数组$response接收查询的数据结果,通过判断不同的情况赋值$response[“success”],并返回到Web页面显示

PHP文件执行结果

Android App端与PHP Web端的简单数据交互的示例分析

JSON

 {  "items": [    {      "what": "手表",      "when": "2017-10-21 00:00:00",      "where": "北区宿舍楼#504",      "detail": "白色的手表,XX品牌",      "posttime": "2017-10-21 13:03:09",      "contact": "138123456"    },    {      "what": "手机",      "when": "2017-10-04 00:00:00",      "where": "北区商店#111",      "detail": "iphone6s,土豪金",      "posttime": "2017-10-21 13:03:46",      "contact": "137123456"    },    {      "what": "电脑",      "when": "2017-10-21 14:39:54",      "where": "图书馆#203",      "detail": "联想品牌笔记本",      "posttime": "2017-10-21 17:08:14",      "contact": "5670001"    },    {      "what": "细说PHP",      "when": "2017-09-21 13:03:46",      "where": "南馆#403",      "detail": "黑色封面,第二版《细说PHP》",      "posttime": "2017-10-21 17:36:53",      "contact": "63513641"    }  ],  "success": 1}

提交数据

create_found_items.php

<?php header('Content-Type:text/html;charset=utf-8');     // 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请求的参数是否都存在,把获取的GET请求参数作为数据INSERT TO MySQL数据库。判断INSERT执行过程赋值$response[“success”]对应相应的$response[“message”],显示在Web页面。

执行结果

Android App端与PHP Web端的简单数据交互的示例分析

Andorid

获取数据

核心代码 queryLosts()函数

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网络框架OKhttp,OKhttp一个处理网络请求的开源项目,是安卓端最火热的轻量级框架.请求接口url地址,获取Json数据利用JSONObject对Json数据进行解析。

提交数据

核心代码 addLost()函数

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方式提交参数,try-catch获取异常,通过返回值给出一定的提交结果提示。

代码测试

数据同步

Web端

Android App端与PHP Web端的简单数据交互的示例分析

Andorid端

Android App端与PHP Web端的简单数据交互的示例分析

数据提交

Android App端与PHP Web端的简单数据交互的示例分析

提交结果

Android App端与PHP Web端的简单数据交互的示例分析

Android App端与PHP Web端的简单数据交互的示例分析

以上是“Android App端与PHP Web端的简单数据交互的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网PHP编程频道!

--结束END--

本文标题: Android App端与PHP Web端的简单数据交互的示例分析

本文链接: https://lsjlt.com/news/220546.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android App端与PHP Web端的简单数据交互的示例分析
    小编给大家分享一下Android App端与PHP Web端的简单数据交互的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!实现流程流程说明Andorid ...
    99+
    2023-05-30
    android php
  • vue-Resource与后端数据交互的示例分析
    这篇文章主要为大家展示了“vue-Resource与后端数据交互的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue-Resource与后端数据交互的...
    99+
    2024-04-02
  • 前端ajax与后端交互的示例分析
    这篇文章主要介绍了前端ajax与后端交互的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前端中常常用的与后端交换数据的话,通常是要用...
    99+
    2024-04-02
  • Vue前后端数据交互与显示的示例分析
    小编给大家分享一下Vue前后端数据交互与显示的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、技术概述将后端所计算的数据呈现在前端页面的相应位置并根据用...
    99+
    2023-06-15
  • Android中WebView与H5前端JS代码交互的示例分析
    这篇文章主要为大家展示了“Android中WebView与H5前端JS代码交互的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android中WebView与H5前端JS代码交互的示例分...
    99+
    2023-05-30
    android webview html5
  • React Native与IOS端之间交互的示例分析
    这篇文章给大家分享的是有关React Native与IOS端之间交互的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前置准备首先最好了解一点关于 oc 的语法知识创建声明文件nativeModule.h#...
    99+
    2023-06-15
  • Android的简单前后端交互(okHttp+springboot+mysql)
    前言 前阵子发现了个有意思又好用的框架——okHttp。由于课程设计需要,无意间发现了这个框架,打算利用此框架与后端交互,可以参考前后端分离的项目,把android当做前端,spri...
    99+
    2024-04-02
  • AngularJS与后端php的数据怎么交互
    这篇文章主要讲解了“AngularJS与后端php的数据怎么交互”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“AngularJS与后端php的数据怎么交互”...
    99+
    2024-04-02
  • web前端中单例模式的示例分析
    小编给大家分享一下web前端中单例模式的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!单例模式(Singleton Pa...
    99+
    2024-04-02
  • Node之简单的前后端交互(实例讲解)
    node是前端必学的一门技能,我们都知道node是用的js做后端,在学习node之前我们有必要明白node是如何实现前后端交互的。 这里写了一个简单的通过原生ajax与node实现的一个交互,刚刚学node...
    99+
    2022-06-04
    实例 后端 简单
  • 微信小程序之表单提交与PHP后台数据交互处理的示例分析
    这篇文章给大家分享的是有关微信小程序之表单提交与PHP后台数据交互处理的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体如下:【form表单提交】form.wxml:&...
    99+
    2024-04-02
  • Kafka简单客户端编程的示例分析
    这篇文章将为大家详细讲解有关Kafka简单客户端编程的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、创建配置类Config这个类很简单,只是存放了两个常量,一个是话题TOPIC,一个是线程数T...
    99+
    2023-05-30
    kafka
  • PHP与JavaScript下Cookie交互使用的示例分析
    小编给大家分享一下PHP与JavaScript下Cookie交互使用的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!PHP与JavaScript下Cookie的交互使用下面的例子列出几种情形交互场景,列出JS和ph...
    99+
    2023-06-15
  • WEB前端跨域的示例分析
    这篇文章主要为大家展示了“WEB前端跨域的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“WEB前端跨域的示例分析”这篇文章吧。 ...
    99+
    2024-04-02
  • web前端与后端分离的架构实例分析
    本篇内容主要讲解“web前端与后端分离的架构实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web前端与后端分离的架构实例分析”吧!一、关于前端的 dat...
    99+
    2024-04-02
  • 前端实现滑动按钮AJAX与后端交互的示例代码
    目录html代码css代码效果图JS事件触发flask后端接口参考链接html代码 <div class="switch-box"> <input id="...
    99+
    2024-04-02
  • web前端外观模式的示例分析
    这篇文章给大家分享的是有关web前端外观模式的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。外观模式(Facade Pattern)外观模式是最常见的设计模式之一,它为子...
    99+
    2024-04-02
  • web前端开发规范的示例分析
    小编给大家分享一下web前端开发规范的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!规范说明此为前端开发团队遵循和约定的...
    99+
    2024-04-02
  • web前端知识体系的示例分析
    小编给大家分享一下web前端知识体系的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在看内容之前,先看一下这个知识框架的...
    99+
    2024-04-02
  • Android端分页加载库的示例分析
    这篇文章主要介绍了Android端分页加载库的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言RecyclerView几乎在每个app里面都有被使用,但凡使用了列表...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作