第一次写api程序,用的原生php,没有restful要求。如果只实现功能返回json数据的话感觉很容易就能实现大部分功能,那么除了功能实现之外需要注意什么问题呢?新手求指导。。已经贴上代码 一共4个文件
<code><?php class Response { /** *按json方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 */ public static function show($code,$message = '', $data = array()){ if(!is_numeric($code)){ return ''; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data ); echo json_encode($result); } }</code>
<code><?php /* * 单例模式 数据库连接 */ require_once ('Response.php'); class Db { static private $_instance; static private $_connectSource; private $_DbConfig = array( 'host' => 'localhost', 'user' => 'root', 'password' => 'xxx', 'database' => 'sportsstore' ); private function __construct() { } static public function getInstace(){ if(!(self::$_instance instanceof self)){ self::$_instance = new self(); } return self::$_instance; } public function connect(){ if(!self::$_connectSource) { self::$_connectSource = mysqli_connect($this->_DbConfig['host'], $this->_DbConfig['user'], $this->_DbConfig['password'],$this->_DbConfig['database']); if(!self::$_connectSource){ throw new Exception("mysql connect error" . mysql_errno()); } } return self::$_connectSource; } } </code>
这个是登录的代码
<code>/* *login.phh 登录接口 */ <?php require_once ('Db.php'); require_once ('Response.php'); try{ $link = Db::getInstace()->connect(); } catch (Exception $ex) { return Response::show(402,"数据库连接失败"); } $account = mysqli_real_escape_string($link, trim($_POST['account'])); $password = mysqli_real_escape_string($link, trim($_POST['password'])); $query = "select * from users where account = \"$account\""; $result = mysqli_query($link, $query); if(mysqli_num_rows($result)==1){ $row = mysqli_fetch_array($result); if($row['password'] == $password){ return Response::show(200, '登录成功'); }else{ return Response::show(202,'密码不正确'); } }else{ return Response::show(201,'账户不存在'); }</code>
<code>/* *getPersonalInfo.phh 查询个人信息接口 */ <?php require_once ('Db.php'); require_once ('Response.php'); try{ $link = Db::getInstace()->connect(); } catch (Exception $ex) { return Response::show(402,'数据库连接失败'); } $account = isset($_GET['account']) ? mysqli_real_escape_string($link, trim($_GET['account'])) : null; if($account === null){ return Response::show(401,'未登录'); } $query = "select * from users where account=\"$account\""; $result = mysqli_query($link, $query); $row = mysqli_fetch_assoc($result); return Response::show(200,"操作成功",$row);</code>
回复内容:
第一次写api程序,用的原生php,没有restful要求。如果只实现功能返回json数据的话感觉很容易就能实现大部分功能,那么除了功能实现之外需要注意什么问题呢?新手求指导。。已经贴上代码 一共4个文件
<code><?php class Response { /** *按json方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 */ public static function show($code,$message = '', $data = array()){ if(!is_numeric($code)){ return ''; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data ); echo json_encode($result); } }</code>
<code><?php /* * 单例模式 数据库连接 */ require_once ('Response.php'); class Db { static private $_instance; static private $_connectSource; private $_DbConfig = array( 'host' => 'localhost', 'user' => 'root', 'password' => 'xxx', 'database' => 'sportsstore' ); private function __construct() { } static public function getInstace(){ if(!(self::$_instance instanceof self)){ self::$_instance = new self(); } return self::$_instance; } public function connect(){ if(!self::$_connectSource) { self::$_connectSource = mysqli_connect($this->_DbConfig['host'], $this->_DbConfig['user'], $this->_DbConfig['password'],$this->_DbConfig['database']); if(!self::$_connectSource){ throw new Exception("mysql connect error" . mysql_errno()); } } return self::$_connectSource; } } </code>
这个是登录的代码
<code>/* *login.phh 登录接口 */ <?php require_once ('Db.php'); require_once ('Response.php'); try{ $link = Db::getInstace()->connect(); } catch (Exception $ex) { return Response::show(402,"数据库连接失败"); } $account = mysqli_real_escape_string($link, trim($_POST['account'])); $password = mysqli_real_escape_string($link, trim($_POST['password'])); $query = "select * from users where account = \"$account\""; $result = mysqli_query($link, $query); if(mysqli_num_rows($result)==1){ $row = mysqli_fetch_array($result); if($row['password'] == $password){ return Response::show(200, '登录成功'); }else{ return Response::show(202,'密码不正确'); } }else{ return Response::show(201,'账户不存在'); }</code>
<code>/* *getPersonalInfo.phh 查询个人信息接口 */ <?php require_once ('Db.php'); require_once ('Response.php'); try{ $link = Db::getInstace()->connect(); } catch (Exception $ex) { return Response::show(402,'数据库连接失败'); } $account = isset($_GET['account']) ? mysqli_real_escape_string($link, trim($_GET['account'])) : null; if($account === null){ return Response::show(401,'未登录'); } $query = "select * from users where account=\"$account\""; $result = mysqli_query($link, $query); $row = mysqli_fetch_assoc($result); return Response::show(200,"操作成功",$row);</code>
Update
数据完整
语义简洁
版本可控
响应灵活
安全可靠(https可以考虑,token机制,ip白名单等)
响应速度
风格统一(不要隔三差五就变,返回的格式统一)
记住一点,不要写json_ecode($array);exit;这样的代码就好。
用自己轻量级的类似apiRespnse($data) 分装,虽然你只返回json.
楼上说的不错,我再加一条。
格式统一
比如返回的数据一定带一个统一名称的“请求状态结果”,比如返回的数据一定统一放一个变量里。
避免出现前台不同的地方要判断不同的名字。
注册的接口 还有抽奖的接口 必须安全性得到保障,防止恶意刷!!!
你先贴上你的代码。我也学习一下。

thesecrettokeepingaphp-poweredwebsterunningsmootlyunderheavyloadinvolvesseveralkeystrategies:1)emform opcodecoduceSciptionexecutiontime、2)aatabasequerycachingwithiThing withiThistolessendavasoload、

コードをより明確かつ維持しやすくするため、依存関係が関心(DI)に注意する必要があります。 1)DIは、クラスを切り離すことにより、よりモジュール化されます。2)テストとコードの柔軟性の利便性を向上させ、3)DIコンテナを使用して複雑な依存関係を管理しますが、パフォーマンスの影響と円形の依存関係に注意してください。

はい、最適化されたAphPossibleandessention.1)CachingingusapCutoredatedAtabaseload.2)最適化、効率的なQueries、およびConnectionPooling.3)EnhcodeCodewithBultinctions、Avoididingglobalbariables、およびUsingopcodeching

keyStrategIestsoSificlyvoostphpappliceperformanceare:1)useopcodecachinglikeToreexecutiontime、2)最適化abaseの相互作用とプロペラインデックス、3)3)構成

aphpDependencyInjectionContaineriSATOULTAINATINAGECLASSDEPTINCIES、強化測定性、テスト可能性、および維持可能性。

SELECT DEPENTENCINGINOFCENT(DI)大規模なアプリケーションの場合、ServicElocatorは小さなプロジェクトまたはプロトタイプに適しています。 1)DIは、コンストラクターインジェクションを通じてコードのテスト可能性とモジュール性を改善します。 2)ServiceLocatorは、センター登録を通じてサービスを取得します。これは便利ですが、コードカップリングの増加につながる可能性があります。

phpapplicationscanbeoptimizedforspeedandEfficiencyby:1)enabingopcacheinphp.ini、2)PreparedStatementswithpordatabasequeriesを使用して、3)LoopswithArray_filterandarray_mapfordataprocessing、4)の構成ngincasaSearverseproxy、5)

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

Dreamweaver Mac版
ビジュアル Web 開発ツール

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

ドリームウィーバー CS6
ビジュアル Web 開発ツール
