L'API RESTful est une architecture de service Web standard basée sur le protocole HTTP. Il s'agit aujourd'hui de la technologie la plus populaire dans le développement de diverses applications Web sur Internet. Les API RESTful peuvent être utilisées pour fournir rapidement de nombreuses données et fonctions différentes à des applications externes ou à d'autres services. Dans cet article, nous présenterons Fat-Free, un framework PHP efficace, et comment l'utiliser pour développer un service API RESTful.
1. Qu'est-ce que le framework Fat-Free ?
Fat-Free est un framework PHP open source léger et flexible. Son nom implique également ses caractéristiques : rapide, simple et compact. Le framework fournit de nombreux modules fonctionnels de base intégrés, tels que le routage, le moteur de modèles, la base de données, etc., ce qui le rend très efficace, simple et flexible lors de la création d'applications Web.
2. Pourquoi utiliser le framework Fat-Free ?
3. Comment utiliser le framework Fat-Free pour développer des services API RESTful ?
Vous pouvez télécharger le package d'installation sur le site officiel de Fat-Free, ou vous pouvez utiliser composer pour l'installer.
Créez un nouveau dossier API dans votre répertoire Web et déplacez le framework Fat-Free vers le dossier API, comme indiqué dans la figure :
├─API/ │ ├─f3/ │ │ ├─lib/ │ │ ├─... │ ├─index.php
Créez un fichier index.php, qui est le fichier d'entrée de notre service API. Nous devons inclure le framework Fat-Free.
<?php $f3 = require('f3/lib/base.php'); // RESTful API 路由 $f3->route('GET /api/@apiname','api@get'); $f3->route('POST /api/@apiname','api@post'); $f3->route('PUT /api/@apiname','api@put'); $f3->route('DELETE /api/@apiname','api@delete'); // 连接数据库 $f3->set('DB', new DBSQL('mysql:host=localhost;port=3306;dbname=test', 'root', 'root')); // 执行 $f3->run();
Dans ce fichier, nous définissons quatre routes, correspondant aux quatre méthodes de requête du protocole HTTP, à savoir GET, POST, PUT et DELETE. Le framework Fat-Free prend en charge le traitement des requêtes via le routage, qui définit la relation de mappage entre les chemins d'URL et les fonctions. Par conséquent, nous définissons un contrôleur appelé api et lui mappons quatre méthodes de requête différentes.
Nous avons besoin d'un contrôleur API pour gérer les demandes initiées par le client et renvoyer les données de réponse correspondantes.
<?php class api { protected $APIVer = 'v1'; private function respond($response) { header('Content-type: application/json; charset=utf-8'); header('Cache-control: max-age=3600'); echo json_encode($response, JSON_PRETTY_PRINT|JSON_UNESCAPED_UNICODE); } public function get($f3) { $request = new WebREST($f3->get('VERB'), @$f3->get('PARAMS.apiname'), @$f3->get('PARAMS.id')); $result = $request->process(); if ($result) { $this->respond($result); $f3->status(200); } else $f3->status(404); } public function post($f3) { $request = new WebREST($f3->get('VERB'), @$f3->get('PARAMS.apiname'), @$f3->get('PARAMS.id')); $result = $request->process(); if ($result) { $this->respond($result); $f3->status(201); } else $f3->status(404); } public function put($f3) { $request = new WebREST($f3->get('VERB'), @$f3->get('PARAMS.apiname'), @$f3->get('PARAMS.id')); $result = $request->process(); if ($result) { $this->respond($result); $f3->status(202); } else $f3->status(404); } public function delete($f3) { $request = new WebREST($f3->get('VERB'), @$f3->get('PARAMS.apiname'), @$f3->get('PARAMS.id')); $result = $request->process(); if ($result) { $this->respond($result); $f3->status(202); } else $f3->status(404); } }
Dans ce contrôleur, quatre méthodes sont définies : get, post, put et delete. Dans ces méthodes, nous devons instancier un objet Web REST et appeler sa méthode de processus pour obtenir les données de réponse. Du point de vue de la réponse HTTP, les données de réponse doivent être au format JSON, donc dans la méthode de réponse, nous utilisons la méthode json_encode de PHP pour convertir les données de réponse en une chaîne JSON et les envoyer au client.
Ce fichier de classe est utilisé pour gérer les requêtes du serveur API RESTful.
<?php namespace Web; class REST { private $verb; // HTTP 请求方法 private $apiname; // API名称 private $id; // API 记录id private $user; // 用户认证信息 protected $db; // 数据库连接 protected $base; // 数据库基本名称 protected $table; // 表名 protected $data; // 用于 POST 和 PUT 请求中的数据 protected $fields = array(); // 表字段名称 protected $response_code = array( 100 => 'Continue', 101 => 'Switching Protocols', 200 => 'OK', 201 => 'Created', 202 => 'Accepted', 203 => 'Non-Authoritative Information', 204 => 'No Content', 205 => 'Reset Content', 206 => 'Partial Content', 300 => 'Multiple Choices', 301 => 'Moved Permanently', 302 => 'Found', 303 => 'See Other', 304 => 'Not Modified', 305 => 'Use Proxy', 307 => 'Temporary Redirect', 400 => 'Bad Request', 401 => 'Unauthorized', 402 => 'Payment Required', 403 => 'Forbidden', 404 => 'Not Found', 405 => 'Method Not Allowed', 406 => 'Not Acceptable', 407 => 'Proxy Authentication Required', 408 => 'Request Timeout', 409 => 'Conflict', 410 => 'Gone', 411 => 'Length Required', 412 => 'Precondition Failed', 413 => 'Request Entity Too Large', 414 => 'Request-URI Too Long', 415 => 'Unsupported Media Type', 416 => 'Requested Range Not Satisfiable', 417 => 'Expectation Failed', 500 => 'Internal Server Error', 501 => 'Not Implemented', 502 => 'Bad Gateway', 503 => 'Service Unavailable', 504 => 'Gateway Timeout', 505 => 'HTTP Version Not Supported' ); public function __construct($verb, $apiname, $id = null, $data = null) { $this->verb = $verb; $this->apiname = $apiname; $this->id = $id; $this->data = $data; $this->db = Base::instance()->get('DB'); } public function process() { //$sql = "SELECT..."; ... } } }
Dans ce fichier de classe, nous implémentons une classe REST qui gère les requêtes du serveur API RESTful. La classe contient le type de méthode de requête HTTP, le nom de l'API, l'ID d'enregistrement API, les données à traiter, etc. Cette classe exploite la base de données, obtient les données pertinentes, crée des requêtes et renvoie des données de réponse.
IV. Conclusion
Comme nous l'avons vu précédemment, il est très facile de développer des services API RESTful à l'aide du framework PHP Fat-Free, car il s'agit d'un framework lui-même léger, et son mécanisme de routage puissant nous permet de définir des routes API avec beaucoup de précision. flexibilité. De plus, il fournit de nombreux modules très utiles pour nous aider à terminer rapidement le développement d'applications Web. C'est la principale raison pour laquelle nous avons choisi Fat-Free comme framework PHP. Ce sont ses caractéristiques légères, efficaces, fiables et flexibles qui nous permettent de créer rapidement des API RESTful exquises.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!