예: http://localhost/openUser.php?act=get_user_list&type=json
여기서 openUser.php는 인터페이스와 동일합니다. 여기서 get_user_list는 API(사용자 목록 가져오기)이고 반환된 데이터 유형입니다. 은 JSON 형식입니다.
PHP 코드에서 이 링크를 실행하기만 하면 해당 링크가 반환됩니다.
GET 메소드 직접 사용
$file_contents = file_get_content('http://localhost/openUser.php?act=get_user_list&type=json')
POST 메소드는 다음을 사용해야 합니다(PHP 컬 지원이 활성화되어야 함).
$url = 'http://localhost/openUser.php?act=get_user_list&type=json'; $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, $url ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_CONNECTTIMEOUT, 10 ); curl_setopt ( $ch, CURLOPT_POST, 1 ); //启用POST提交 $file_contents = curl_exec ( $ch ); curl_close ( $ch );
php에서 인터페이스 작성
1. 먼저 두 가지 질문에 간략하게 답해 보세요.
1. PHP가 클라이언트를 개발할 수 있나요?
답변: 아니요. PHP는 스크립팅 언어이고 B/S 아키텍처 또는 C/S 아키텍처의 S 부분, 즉 서버 개발을 완료하는 역할을 담당하기 때문입니다. (GTK와 WinBinder는 걱정하지 마세요)
2. 서버 개발의 첫 번째 선택으로 PHP를 선택하는 이유는 무엇입니까?
답변: 크로스 플랫폼(UNIX, LINUX, WINDOWS, Mac OS에서 실행 가능), 낮은 소비(PHP는 시스템 리소스를 거의 사용하지 않음), 높은 운영 효율성(상대적으로 말하면), MySQL의 완벽한 파트너이며 무료이며 오픈 소스,...
2. PHP를 사용하여 API(응용 프로그래밍 인터페이스, 응용 프로그래밍 인터페이스)를 개발하는 방법은 무엇입니까?
API 작업을 해본 사람들은 실제로 API 개발이 WEB 개발보다 간단하다는 것을 이해해야 하지만 API는 실제로 페이지를 렌더링하지 않고 데이터를 출력하는 것이므로 MVC가 없기 때문에 로직이 더 복잡할 수 있습니다(API에는 M만 있습니다) C)
1. WEB 개발과 마찬가지로 먼저 몇 가지 관련 매개변수가 클라이언트에서 전달됩니다. 이는 개발 팀의 동의가 필요하거나 통합 사양이 공식화될 수 있습니다. .
2. 매개변수를 사용하여 작업 진행 상황 업데이트, 앱 내 구매, 게임 종료 데이터 제출 등 애플리케이션 요구 사항에 따라 데이터 처리를 완료합니다.
3. 클라이언트에 필요한 것 미션 상태, 인앱 구매 결과, 플레이어 정보 등과 같은 관련 데이터입니다. 데이터는 클라이언트에 어떻게 반환됩니까?
JSON, XML, TEXT 등과 같은 직접 출력 형식
4. 클라이언트는 반환된 데이터를 받은 후 클라이언트에서 로컬로 사용자와 상호 작용합니다.
임시로 작성된 간단한 API 예:
<?php $output = array(); $a = @$_GET['a'] ? $_GET['a'] : ''; $uid = @$_GET['uid'] ? $_GET['uid'] : 0; if (empty($a)) { $output = array('data'=>NULL, 'info'=>'坑爹啊!', 'code'=>-201); exit(json_encode($output)); } //走接口 if ($a == 'get_users') { //检查用户 if ($uid == 0) { $output = array('data'=>NULL, 'info'=>'The uid is null!', 'code'=>-401); exit(json_encode($output)); } //假设 $mysql 是数据库 $mysql = array( 10001 => array( 'uid'=>10001, 'vip'=>5, 'nickname' => 'Shine X', 'email'=>'979137@qq.com', 'qq'=>979137, 'gold'=>1500, 'powerplay'=> array('2xp'=>12,'gem'=>12,'bingo'=>5,'keys'=>5,'chest'=>8), 'gems'=> array('red'=>13,'green'=>3,'blue'=>8,'yellow'=>17), 'ctime'=>1376523234, 'lastLogin'=>1377123144, 'level'=>19, 'exp'=>16758, ), 10002 => array( 'uid'=>10002, 'vip'=>50, 'nickname' => 'elva', 'email'=>'elva@ezhi.net', 'qq'=>NULL, 'gold'=>14320, 'powerplay'=> array('2xp'=>1,'gem'=>120,'bingo'=>51,'keys'=>5,'chest'=>8), 'gems'=> array('red'=>13,'green'=>3,'blue'=>8,'yellow'=>17), 'ctime'=>1376523234, 'lastLogin'=>1377123144, 'level'=>112, 'exp'=>167588, ), 10003 => array( 'uid' => 10003, 'vip' => 5, 'nickname' => 'Lily', 'email' => 'Lily@ezhi.net', 'qq' => NULL, 'gold' => 1541, 'powerplay'=> array('2xp'=>2,'gem'=>112,'bingo'=>4,'keys'=>7,'chest'=>8), 'gems' => array('red'=>13,'green'=>3,'blue'=>9,'yellow'=>7), 'ctime' => 1376523234, 'lastLogin'=> 1377123144, 'level' => 10, 'exp' => 1758, ), ); $uidArr = array(10001,10002,10003); if (in_array($uid, $uidArr, true)) { $output = array('data' => NULL, 'info'=>'The user does not exist!', 'code' => -402); exit(json_encode($output)); } //查询数据库 $userInfo = $mysql[$uid]; //输出数据 $output = array( 'data' => array( 'userInfo' => $userInfo, 'isLogin' => true,//是否首次登陆 'unread' => 4,//未读消息数量 'untask' => 3,//未完成任务 ), 'info' => 'Here is the message which, commonly used in popup window', //消息提示,客户端常会用此作为给弹窗信息。 'code' => 200, //成功与失败的代码,一般都是正数或者负数 ); exit(json_encode($output)); } elseif ($a == 'get_games_result') { //... die('您正在调 get_games_result 接口!'); } elseif ($a == 'upload_avatars') { //.... die('您正在调 upload_avatars 接口!'); }코드 복사클릭 테스트(클라이언트의 경우에도 직접 호출) 해당 주소):
http://www.ezhi.net/api/test/index.php http://www.ezhi.net/api/test/index.php?a=get_users http://www.ezhi.net/api/test/index.php?a=get_users&uid=10001 http://www.ezhi.net/api/test/index.php?a=get_users&uid=10002 http://www.ezhi.net/api/test/index.php?a=get_users&uid=10003
三、实际项目中,我们在开发 API 应该注意的几个事项(仅供参考):
1、单文件实现多接口的形式有很多种,例如:if..elseif.. 或 switch 或 动态方法 (也就是TP的这种访问函数体的形式)
2、对于数据的输出最好用json,json具有相当强大的跨平台性,市场上各大主流编程语言都支持json解析,json正在逐步取代xml,成为网络数据的通用格式
3、接口安全,一定要增加接口验证。例如,客户端和服务端针对不同接口统一做好加密方式,服务端在对于每次接口需要都要进行验证。以保证防止接口被恶意刷新或黑客恶意调用,尤其是大型商业应用。
4、对于线上的 API 必须保证所有接口正常且关闭所有的错误信息 => error_reporting(0),在输出JSON 时,不能有任何其它输出,否则,客户端将解析数据失败,直接 Crash!
5、开发 API 和 WEB 有一定的区别,如果是 WEB 的话,可能代码出错了,不会导致特别严重的错误,也许只是导致数据写入和查询失败,也许导致 WEB 的某个部分错位或乱码。但如果是 API,直接 Crash!
6、做接口开发,不建议使用框架开发,原因概括起来有两点(其实我有点冒风险的,本人也是 TPer 一枚,毕竟这是TP的官网):
1)客户端一般对服务端的响应速度有极高要求,因此,使用最原生态的 PHP 完成接口开发,是最高效的,假如用到了框架,还需要加载各种不需要多余的文件,就好比夏天穿了件冬天的衣服。试想,你在玩手机的时候,使用一个应用随便一个操作,等半天才有动静,你受的了吗?
2)就是上面第4点提到的,框架对于WEB开发,是件很幸福的事,但对于 API 而言,你实在不敢想象它会给你出什么岔子!最后你将痛苦不堪~~因为很多框架都是为 WEB 诞生的(我也很期待有一天能看到专门为开发 API 而生的框架或者扩展)
这个也有人纠结,接口效率与稳定性,还得看编码的人,有的人可能写的还不如框架跑的快,也有人觉得用框架没什么问题,这里只是建议,关键看自己的实际情况,同时建议代码上线前压测一下
说到这,不得不说扯一下,腾讯微博淘宝等开放平台。其实那些开放平台,所谓的开放,就是给你提供一个这样的接口,你根据他们提供的技术文档,按他们制定的格式和要求,调它们提供的接口文件(一般都是返回JSON或者XML),你就可以获取到他们的相关信息,例如:QQ用户基本信息、淘宝店铺、商品消息等等。然后在根据这些消息,在你的应用里完成交互。
其实,ajax 也是调用 API 的接口
위 내용은 PHP에서 인터페이스를 호출하고 인터페이스 코드를 작성하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!