本篇文章介绍的是关于PHP服务端开发APP接口 ,现在给大家分享一下,有兴趣的朋友可以看一下
一、APP接口简介
什么是app接口?app接口就是用服务端程序如php写好的脚本,以供app客户端请求而获得数据的一个东西。比如一个商铺app的首页,肯定有一些商品列表,那么当你打开这个app时,这个封装在app里的这个首页其实会去请求一个远程php文件如:http://www.example.com/index.php 去获得需要展示在首页的商品列表数据。前端工程师拿到这些数据,就会按照特定的设计,将这些内容展示出来了。
接口要实现的目的就是这样。一个app内部通常需要访问多个php接口来获得不同的数据。下面具体讲一讲接口实现的流程以及实现接口需要的一些核心的技术。
二、PHP接口知识
JSON和XML方式封装通信接口
response.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); }?>
(上述代码都是根据本人项目需要开发的相应接口)
相关推荐:
七牛云存储 - PILI直播 PHP服务端SDK 代码怎么引入到自己的项目中?
以上是PHP服务端开发APP接口的详细内容。更多信息请关注PHP中文网其他相关文章!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。