Dengan perkembangan teknologi Internet, API Web telah menjadi teras kepada banyak aplikasi. Sama ada anda sedang membangunkan aplikasi mudah alih, pengkomputeran awan atau aplikasi SaaS, API Web memainkan peranan penting. Cara mereka bentuk API yang cekap telah menjadi salah satu teknologi yang perlu dikuasai oleh pembangun web. Artikel ini akan memperkenalkan teknik untuk mereka bentuk API yang cekap menggunakan PHP.
RESTful API ialah gaya reka bentuk API Web yang popular. Ia berdasarkan protokol HTTP, menggunakan kaedah HTTP seperti GET, POST, PUT dan DELETE untuk mengendalikan sumber, dan mengembalikan hasil menggunakan kod status HTTP dan format JSON/XML.
Anda perlu mengikut spesifikasi berikut semasa mereka bentuk API RESTful:
Sebagai contoh, untuk mendapatkan maklumat pengguna, anda boleh menggunakan kaedah HTTP dan URL berikut:
JSON Web Token (JWT) ialah standard berasaskan JSON untuk mencipta token akses untuk memindahkan maklumat antara pelayan dengan mudah. Menggunakan JWT untuk pengesahan boleh memperoleh kelebihan berikut:
JWT berasaskan piawaian dan mudah untuk dilaksanakan dan digunakan<?php use FirebaseJWTJWT; //生成JWT $key = "secret_key"; $payload = array( "sub" => "123", "name" => "John Doe", "iat" => time(), "exp" => time() + 3600 ); $jwt = JWT::encode($payload, $key); //验证JWT try { $decoded = JWT::decode($jwt, $key, array('HS256')); print_r($decoded); } catch (Exception $e) { echo 'Caught exception: ', $e->getMessage(), " "; }
Menggunakan ORM untuk operasi pangkalan data
Peta setiap jadual pangkalan data sebagai kelas PHP
<?php // 创建PDO对象 $db = new PDO('mysql:host=localhost;dbname=mydb', 'username', 'password'); $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 查询 $stmt = $db->query('SELECT * FROM users'); $rows = $stmt->fetchAll(PDO::FETCH_ASSOC); // 插入 $stmt = $db->prepare("INSERT INTO users (name, email) VALUES (:name, :email)"); $stmt->bindParam(':name', $name); $stmt->bindParam(':email', $email); $name = 'John Doe'; $email = 'john.doe@email.com'; $stmt->execute(); // 更新 $stmt = $db->prepare("UPDATE users SET name=:name WHERE id=:id"); $stmt->bindParam(':name', $name); $stmt->bindParam(':id', $id); $name = 'Jane Doe'; $id = 1; $stmt->execute(); // 删除 $stmt = $db->prepare("DELETE FROM users WHERE id=:id"); $stmt->bindParam(':id', $id); $id = 2; $stmt->execute();
Menggunakan cache untuk meningkatkan prestasi API
Mudah digunakan, tidak perlu memasang perisian tambahan
<?php $cache = new Memcached(); $cache->addServer('localhost', 11211); // 从缓存中获取数据 if ($result = $cache->get('data')) { echo 'Data from cache: ' . $result; } else { // 从数据库中获取数据 $db = new PDO('mysql:host=localhost;dbname=mydb', 'username', 'password'); $stmt = $db->query('SELECT * FROM data'); $rows = $stmt->fetchAll(PDO::FETCH_ASSOC); $result = json_encode($rows); // 将数据保存到缓存中 $cache->set('data', $result, 3600); echo 'Data from database: ' . $result; }
Kebolehskalaan Baik, sesuai untuk aplikasi besar;
<?php $redis = new Redis(); $redis->connect('localhost', 6379); // 从缓存中获取数据 if ($result = $redis->get('data')) { echo 'Data from cache: ' . $result; } else { // 从数据库中获取数据 $db = new PDO('mysql:host=localhost;dbname=mydb', 'username', 'password'); $stmt = $db->query('SELECT * FROM data'); $rows = $stmt->fetchAll(PDO::FETCH_ASSOC); $result = json_encode($rows); // 将数据保存到缓存中 $redis->set('data', $result); echo 'Data from database: ' . $result; }
Atas ialah kandungan terperinci Teknik untuk mereka bentuk API yang cekap menggunakan PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!