>  기사  >  백엔드 개발  >  PHP 서버 개발 APP 인터페이스

PHP 서버 개발 APP 인터페이스

不言
不言원래의
2018-04-26 14:42:558875검색

이 기사에서는 PHP 서버의 APP 인터페이스 개발을 소개합니다. 관심 있는 친구들은 한 번 살펴보세요


앱 인터페이스란 무엇인가요? 앱 인터페이스는 앱 클라이언트가 데이터를 요청하고 획득하기 위해 PHP와 같은 서버측 프로그램으로 작성된 스크립트입니다. 예를 들어, 스토어 앱의 홈페이지에는 일부 제품 목록이 있어야 하므로 앱을 열 때 앱에 캡슐화된 홈페이지는 실제로 http://www.example.com/index 와 같은 원격 PHP 파일을 요청합니다. 홈페이지에 표시해야 하는 제품 목록 데이터를 얻으려면 php를 사용하세요. 프론트엔드 엔지니어가 이 데이터를 받으면 특정 디자인에 따라 콘텐츠를 표시하게 됩니다.

이것이 인터페이스의 목적입니다. 앱은 일반적으로 다양한 데이터를 얻기 위해 여러 PHP 인터페이스에 액세스해야 합니다. 인터페이스 구현 과정을 구체적으로 설명하고, 인터페이스 구현에 필요한 몇 가지 핵심 기술에 대해 이야기해보겠습니다.


2. 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(&#39;Content-Type:text/xml&#39;);        $xml = "<?xml version=&#39;1.0&#39; encoding=&#39;UTF-8&#39;?>\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=&#39;{$key}&#39;";                    $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);

3. 실제 개발 예시



3가지 인터페이스(로그인, 등록, 파일 업로드)를 개발하여 각각 해당 기능을 완료

  • 저는 APP 개발을 하지 않기 때문에 실제 인터페이스 테스트 과정에서 Firefox 브라우저의 RESTClient 확장을 사용하여 APP 요청 서비스 및 데이터 수신을 시뮬레이션합니다.

    (1) 로그인 및 등록 인터페이스 작성

    직접 코드:
  • <?phprequire ("../connect_db.php");$action = $_REQUEST["action"];$conn = db_connect();
    mysql_query("set names &#39;utf8&#39;");
    mysql_select_db("FECG");switch ($action){    case &#39;login&#39;:
           login();       break;    case &#39;register&#39;:
           register();       break;    case &#39;upload&#39;:
           upload();       break;    default:       break;
    }//登录接口function login(){
        $account_name = $_POST["username"];    $password = $_POST["password"];    $result = mysql_query("SELECT * FROM app_account WHERE account_name=&#39;".$account_name."&#39;");    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(&#39;Y-m-d H:i:s&#39;);            $result =  mysql_query("UPDATE app_account SET last_lgin_time=&#39;".$login_time."&#39; WHERE account_name=&#39;".$row[&#39;account_name&#39;]."&#39;");            $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=&#39;".$account_name."&#39;");    //查询失败
        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(&#39;Y-m-d H:i:s&#39;);        $last_login_time = $create_time;        $result = mysql_query("insert into app_account(account_id,account_name,password,salt,creat_time,last_lgin_time) values(&#39;".$account_id."&#39;, &#39;".$account_name."&#39;, &#39;".$new_password."&#39;, &#39;".$salt."&#39;, &#39;".$create_time."&#39;, &#39;".$last_login_time."&#39;)");        $user_id = uniqid();        $result1 = mysql_query("INSERT INTO app_user(user_id,username,account_id) VALUES(&#39;".$user_id."&#39;, &#39;".$account_name."&#39;, &#39;".$account_id."&#39;)");        if ($result){           $json = json_encode(array(                 "resultCode"=>200,                 "message"=>"register successed!"
                     ));           echo($json);
            }
        }
    }//文件上传接口function upload(){}?>

    RESTClient 테스트:

  • (등록도 비슷한 작업입니다.)
(2) 파일 업로드

시뮬레이션이고 파일 업로드 인터페이스에는 파일 업로드가 포함되어 있으므로 RESTClient는 이를 시뮬레이션할 수 없습니다. 따라서 파일 업로드를 시뮬레이션하려면 별도의 클라이언트 uploadClient.html을 작성하세요.
uploadClient.htmlPHP 서버 개발 APP 인터페이스

<!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 &#39;utf8&#39;");
mysql_select_db("FECG");$file_name = $_POST["filename"];$userid = $_POST["userid"];$heart_rate = $_POST["rate"];if ($_FILES[&#39;filename&#39;][&#39;name&#39;] != NULL){    if ($_FILES[&#39;filename&#39;][&#39;error&#39;]){        $data = array(            "resultCode"=>1,            "message"=>"失败,上传文件出错!"
        );        echo json_encode($data);
    }    else{        //获取文件后缀名
        $file_extension = substr(strrchr($_FILES[&#39;filename&#39;][&#39;name&#39;], &#39;.&#39;), 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 = &#39;/var/www/html/FECG/fecg_segment_data/&#39;.$userid.&#39;/&#39;.date("YmdHis").".".$file_extension;        if (is_uploaded_file($_FILES[&#39;filename&#39;][&#39;tmp_name&#39;])){            $result = move_uploaded_file($_FILES[&#39;filename&#39;][&#39;tmp_name&#39;], $file_path);            if ($result){                //文件上传成功,进行第二步更新数据库
                $result = mysql_query("SELECT * FROM app_account WHERE account_name=&#39;".$userid."&#39;");                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=&#39;".$account_id."&#39;");                $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(&#39;Y-m-d H:i:s&#39;);                $result = mysql_query("INSERT INTO ecg_segment(ecg_segment_id,channel,heart_rate,ecg_url,user_name,user_id)
                                      VALUES(&#39;".$ecg_segment_id."&#39;, &#39;".$channel."&#39;, &#39;".$heart_rate."&#39;, &#39;".$file_path."&#39;, &#39;".$user_name."&#39;, &#39;".$user_id."&#39;)");                $task_id = uniqid();                $server_analysis = "异常";                $result1 = mysql_query("INSERT INTO task(task_id,creat_time,server_analysis,ecg_segment_id)
                                      VALUES(&#39;".$task_id."&#39;, &#39;".$create_time."&#39;, &#39;".$server_analysis."&#39;, &#39;".$ecg_segment_id."&#39;)");                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 서버 환경 구축에 대한 그래픽 튜토리얼

Qiniu Cloud Storage-PILI 라이브 방송 자신의 프로젝트에 PHP 서버 SDK 코드를 도입하는 방법은 무엇입니까?

모바일 단말기와 PHP 서버 인터페이스 간의 통신 프로세스 설계 개선 버전

위 내용은 PHP 서버 개발 APP 인터페이스의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.