亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

PHP服務端開發APP接口

2020-03-22 18:43:22
字體:
來源:轉載
供稿:網友
本篇文章介紹的是關于PHP服務端開發APP接口 ,現在給大家分享一下,有興趣的朋友可以看一下


一、APP接口簡介


什么是app接口?app接口就是用服務端程序如php寫好的腳本,以供app客戶端請求而獲得數據的一個東西。比如一個商鋪app的首頁,肯定有一些商品列表,那么當你打開這個app時,這個封裝在app里的這個首頁其實會去請求一個遠程php文件如:http://www.example.com/index.php 去獲得需要展示在首頁的商品列表數據。前端工程師拿到這些數據,就會按照特定的設計,將這些內容展示出來了。
接口要實現的目的就是這樣。一個app內部通常需要訪問多個php接口來獲得不同的數據。下面具體講一講接口實現的流程以及實現接口需要的一些核心的技術。


二、PHP接口知識JSON和XML方式封裝通信接口

response.html' target='_blank'>class.php

<?php/** *description 用于返回指定數據格式的類 *@param $code [int] 返回的狀態碼 *@param $message [string] 返回的狀態信息 *@param $data [array] 需要返回的數據 * */class Response{    public function json($code,$message,$data){        $result = array(                "code" => $code,                "message" => $message,                "data" => $data            );        return json_encode($result);    }    public function xml($code,$message,$data){        $result = array(                "code" => $code,                "message" => $message,                "data" => $data            );        header('Content-Type:text/xml');        $xml = "<?xml version='1.0' encoding='UTF-8'?>/n";        $xml .= "<root>";        $xml .= self::encodeXml($result);        $xml .= "</root>";        return $xml;    }    /**     *將數據解析為XML字符串     */    public static function encodeXml($data){        $attr = $xml = "";        foreach($data as $key => $value){                if(is_numeric($key)){                    $attr = " id='{$key}'";                    $key = "item";                }                $xml .= "<{$key}{$attr}>";                $xml .= is_array($value)?self::encodeXml($value):$value;                $xml .= "</$key>";        }        return $xml;    }}

response.class.php是一個最簡單的返回json或XML格式數據的類
下面貼出接口文件代碼:
returndata.php

<?phprequire "response.class.php";    //引入返回信息類//準備返回數據$code = 200;$message = "信息請求成功";$data = array(        "name" => "ruanwnewu",        "sex"  => "1",        "age"  => "28",        "exp" => array(                "2012" => "北京瑞泰新",                "2013" => "兄弟連",                "2014" => "木螞蟻科技"            )    );//實例化response類$response = new Response;//返回數據echo $response -> json($code,$message,$data);
三、實際開發例子
  • 開發三個接口(登錄、注冊、文件上傳),分別完成對應的功能

  • 因為本人不做APP開發,所以在實際的接口測試過程中,運用Firefox瀏覽器的RESTClient擴展模擬APP請求服務和接收數據
    (1)登錄、注冊接口的編寫
    直接上代碼:

<?phprequire ("../connect_db.php");$action = $_REQUEST["action"];$conn = db_connect();mysql_query("set names 'utf8'");mysql_select_db("FECG");switch ($action){    case 'login':       login();       break;    case 'register':       register();       break;    case 'upload':       upload();       break;    default:       break;}//登錄接口function login(){    $account_name = $_POST["username"];    $password = $_POST["password"];    $result = mysql_query("SELECT * FROM app_account WHERE account_name='".$account_name."'");    if (mysql_num_rows($result) > 0){        $row = mysql_fetch_array($result);        $salt = $row["salt"];        $new_password = md5($password."".$salt);        if ($new_password == $row["password"]){            //登錄成功            $current_time = new DateTime();            $login_time = $current_time -> format('Y-m-d H:i:s');            $result =  mysql_query("UPDATE app_account SET last_lgin_time='".$login_time."' WHERE account_name='".$row['account_name']."'");            $array = array();            $array["account_id"] = $row["account_id"];            $array["account_name"] = $row["account_name"];            $array["create_time"] = $row["creat_time"];            $json = json_encode(array(                  "resultCode"=>200,                  "message"=>"login successed!",                  "data"=>$array));            echo($json);        }else{            $json = json_encode(array(                  "resultCode"=>500,                  "message"=>"The password is wrong!please try again."                  ));            echo($json);         }    }else{        //登錄失敗        $json = json_encode(array(              "resultCode"=>500,              "message"=>"please register!"              ));        echo($json);    }}//注冊接口function register(){    $account_name = $_POST["username"];    $password = $_POST["password"];    $result = mysql_query("select * from app_account where account_name='".$account_name."'");    //查詢失敗    if (!$result){        $json = json_encode(array(              "resultCode"=>500,              "message"=>"select failed!"              ));        echo($json);    }    //用戶名已經注冊    if (mysql_num_rows($result) > 0){        $json = json_encode(array(              "resultCode"=>500,              "message"=>"register failed!"              ));        echo($json);    }else{        //插入記錄到數據庫中        $account_id = uniqid();        $salt = uniqid();        $new_password = md5($password."".$salt);        $current_time = new DateTime();        $create_time = $current_time -> format('Y-m-d H:i:s');        $last_login_time = $create_time;        $result = mysql_query("insert into app_account(account_id,account_name,password,salt,creat_time,last_lgin_time) values('".$account_id."', '".$account_name."', '".$new_password."', '".$salt."', '".$create_time."', '".$last_login_time."')");        $user_id = uniqid();        $result1 = mysql_query("INSERT INTO app_user(user_id,username,account_id) VALUES('".$user_id."', '".$account_name."', '".$account_id."')");        if ($result){           $json = json_encode(array(                 "resultCode"=>200,                 "message"=>"register successed!"                 ));           echo($json);        }    }}//文件上傳接口function upload(){}?>

RESTClient測試:
這里寫圖片描述
(注冊也是類似的操作)
(2)文件上傳
因為是模擬,而文件上傳接口涉及到文件的上傳,RESTClient無法模擬。所以單獨寫一個客戶端uploadClient.html來模擬文件上傳。
uploadClient.html

<!DOCTYPE html><html><head>    <title>文件上傳</title>    <meta charset="UTF-8" /></head><body><form action="upload.php" method="post" enctype="multipart/form-data" >    選擇文件:<input type="file" name="filename" />    </br>    用戶ID:<input type="text" name="userid" /></br>    心率:<input type="text" name="rate" /></br>    <input type="submit" value="提交"></form></body></html>

服務端接收文件接口upload.php
upload.php

<?phprequire ("../connect_db.php");$conn = db_connect();mysql_query("set names 'utf8'");mysql_select_db("FECG");$file_name = $_POST["filename"];$userid = $_POST["userid"];$heart_rate = $_POST["rate"];if ($_FILES['filename']['name'] != NULL){    if ($_FILES['filename']['error']){        $data = array(            "resultCode"=>1,            "message"=>"失敗,上傳文件出錯!"        );        echo json_encode($data);    }    else{        //獲取文件后綴名        $file_extension = substr(strrchr($_FILES['filename']['name'], '.'), 1);        //判斷文件夾是否存在        $path = "/var/www/html/FECG/fecg_segment_data/".$userid;        if (!file_exists($path)){            //創建以用戶名命名的文件夾            if(mkdir ($path)){               $data = array("message"=>"ok");               echo json_encode($data);}        }        //對上傳文件進行命名        $file_path = '/var/www/html/FECG/fecg_segment_data/'.$userid.'/'.date("YmdHis").".".$file_extension;        if (is_uploaded_file($_FILES['filename']['tmp_name'])){            $result = move_uploaded_file($_FILES['filename']['tmp_name'], $file_path);            if ($result){                //文件上傳成功,進行第二步更新數據庫                $result = mysql_query("SELECT * FROM app_account WHERE account_name='".$userid."'");                if (!$result){                     $num = 123;                     $data = array(                        "resultCode"=>2,                        "message"=>"userid",                        "data"=>$userid                     );                     echo json_encode($data);                }                $row = mysql_fetch_array($result, MYSQL_ASSOC);                $account_id = $row["account_id"];                $result1 = mysql_query("SELECT * FROM app_user WHERE account_id='".$account_id."'");                $row1 = mysql_fetch_array($result1, MYSQL_ASSOC);                $user_id = $row1["user_id"];                $user_name = $row1["username"];                $ecg_segment_id = uniqid();                $channel = 3;                $current_time = new DateTime();                $create_time = $current_time -> format('Y-m-d H:i:s');                $result = mysql_query("INSERT INTO ecg_segment(ecg_segment_id,channel,heart_rate,ecg_url,user_name,user_id)                                      VALUES('".$ecg_segment_id."', '".$channel."', '".$heart_rate."', '".$file_path."', '".$user_name."', '".$user_id."')");                $task_id = uniqid();                $server_analysis = "異常";                $result1 = mysql_query("INSERT INTO task(task_id,creat_time,server_analysis,ecg_segment_id)                                      VALUES('".$task_id."', '".$create_time."', '".$server_analysis."', '".$ecg_segment_id."')");                if ($result){                    $data = array(                        "resultCode"=>2,                        "message"=>"文件上傳成功!"                        );                    echo json_encode($data);                }                else{                    $data = array(                        "resultCode"=>3,                        "message"=>"服務器錯誤!"                        );                    echo json_encode($data);                }            }            else{                $data = array(                    "resultCode"=>4,                    "message"=>"uploaded failed!"                    );                echo json_encode($data);            }        }        else{            $data = array(                "resultCode"=>5,                "message"=>"文件上傳失敗!"            );            echo json_encode($data);        }    }}else{    $data = array(         "resultCode"=>300,         "message"=>"文件名不能為空!"         );    echo json_encode($data);}?>

(上述代碼都是根據本人項目需要開發的相應接口)

相關推薦:

最清晰的PHP服務端環境搭建的圖文教程

七牛云存儲 - PILI直播 PHP服務端SDK 代碼怎么引入到自己的項目中?

移動端與PHP服務端接口通信流程設計增強版

以上就是PHP服務端開發APP接口的詳細內容,更多請關注 其它相關文章!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人福利在线观看| 亚洲国产精品久久久久秋霞不卡| 欧美午夜片欧美片在线观看| 亚洲国产日韩精品在线| 久久久久久亚洲精品不卡| 欧美激情一级欧美精品| 亚洲欧美国产一本综合首页| 亚洲天堂第二页| 精品免费在线观看| 日韩免费在线电影| 国产欧美一区二区三区在线看| 欧美高清视频一区二区| 国产成人极品视频| 国产在线精品一区免费香蕉| 日韩在线视频二区| 亚洲系列中文字幕| 色综合色综合网色综合| 国外成人在线视频| 成人激情黄色网| 国产成人精品一区| 久久久久久久久久久亚洲| 亚洲人成在线免费观看| 2020国产精品视频| 亚洲国产精品成人精品| 久久久精品电影| 亚洲午夜色婷婷在线| 色噜噜国产精品视频一区二区| 中文字幕日本欧美| 精品国产91久久久久久老师| 中日韩美女免费视频网址在线观看| 国产成人综合一区二区三区| 青草热久免费精品视频| 国产精品av网站| 欧美福利视频网站| 欧美黑人性视频| 精品久久久久久亚洲精品| 国模视频一区二区| 国产视频精品自拍| 久久精品99久久香蕉国产色戒| 日韩网站免费观看高清| 亚洲第一级黄色片| 日本国产精品视频| 91国产精品视频在线| 亚洲欧美日韩中文在线制服| 欧美激情视频一区二区三区不卡| 欧美日韩免费区域视频在线观看| 日本午夜精品理论片a级appf发布| 国产97在线视频| 亚洲福利在线播放| 国产精品高清在线观看| 91天堂在线视频| 国产丝袜一区二区三区| 日韩极品精品视频免费观看| 97久久超碰福利国产精品…| 成人国产精品久久久| 日韩精品在线免费播放| 久久精品电影一区二区| 热re99久久精品国产66热| 日韩黄在线观看| 日本精品免费一区二区三区| 精品国产一区久久久| 欧美黄色片免费观看| 欧美老女人性视频| 动漫精品一区二区| 538国产精品视频一区二区| 亚洲一区二区三区成人在线视频精品| 国产婷婷色综合av蜜臀av| 九九热在线精品视频| 亚洲国产一区自拍| 中文字幕在线看视频国产欧美| 欧美福利视频在线| 欧美—级高清免费播放| 成人精品在线观看| 国产成人欧美在线观看| 日韩中文字在线| 成人在线小视频| 久久视频在线直播| 亚洲有声小说3d| 国产精品精品一区二区三区午夜版| 国产欧美精品日韩| 夜夜嗨av色一区二区不卡| 国产成人精品日本亚洲专区61| 亚洲奶大毛多的老太婆| 亚洲另类图片色| 国产精品黄色av| 欧美精品中文字幕一区| 成人有码在线视频| 色婷婷久久一区二区| 欧美日韩另类字幕中文| 日韩精品视频免费专区在线播放| 97视频在线观看网址| 亚洲毛片在线观看.| 久久成人精品一区二区三区| 国产成人精品一区二区在线| 日韩精品有码在线观看| 国产成人鲁鲁免费视频a| 久久国产一区二区三区| 精品少妇一区二区30p| 亚洲图片在区色| 欧美激情一区二区三区高清视频| 78m国产成人精品视频| 97国产精品人人爽人人做| 亚洲无限乱码一二三四麻| 国产啪精品视频网站| 久久网福利资源网站| 欧美电影免费观看网站| 久久影视电视剧凤归四时歌| 亚洲成人黄色在线| 在线亚洲午夜片av大片| 亚洲奶大毛多的老太婆| 91精品综合久久久久久五月天| 麻豆国产精品va在线观看不卡| 亚洲毛片一区二区| 色樱桃影院亚洲精品影院| 全亚洲最色的网站在线观看| 欧美午夜视频在线观看| 欧美另类在线播放| 日韩成人在线电影网| 亚洲欧美激情精品一区二区| 大伊人狠狠躁夜夜躁av一区| 亚洲一区二区三区777| 欧美精品18videos性欧| 亚洲欧美一区二区三区四区| 在线亚洲男人天堂| 亚洲最新视频在线| 国产精品久久中文| 91精品国产91久久久久| 欧美电影免费在线观看| xxxxx成人.com| 国产a∨精品一区二区三区不卡| 国产精品久久久久久中文字| 国产z一区二区三区| 色99之美女主播在线视频| 97视频在线观看网址| 欧美一级高清免费播放| 久久亚洲精品毛片| 国产精品久久久久aaaa九色| 成人福利在线观看| 国产精品久久久久久久久借妻| 成人福利视频在线观看| 精品人伦一区二区三区蜜桃免费| 一区二区三区视频免费在线观看| 精品日本美女福利在线观看| 亚洲成人网在线观看| 91精品久久久久久久久不口人| 福利微拍一区二区| 欧美色videos| 久久精品免费播放| 国产精品美乳在线观看| 国产婷婷色综合av蜜臀av| 欧美激情在线有限公司| 精品国产一区二区三区四区在线观看| 操日韩av在线电影| 国产suv精品一区二区| 亚洲欧美日韩区| 亚洲成人网av| 亚洲一级片在线看| 成人午夜两性视频| 色偷偷噜噜噜亚洲男人| 超碰日本道色综合久久综合| 亚洲激情中文字幕| 这里精品视频免费| 51精品在线观看| 欧美一级免费看|