PHP Hyperf ialah rangka kerja mikro perkhidmatan berprestasi tinggi yang digunakan secara meluas dalam pembangunan syarikat Internet yang besar. Artikel ini akan memperkenalkan amalan terbaik untuk pembangunan perkhidmatan mikro menggunakan PHP Hyperf, daripada prototaip kepada persekitaran pengeluaran.
1. Persediaan persekitaran
Sebelum anda mula menggunakan PHP Hyperf untuk pembangunan perkhidmatan mikro, anda perlu menyediakan persekitaran. Mula-mula, pastikan persekitaran pengendalian PHP telah dipasang dan versinya ialah 7.2 ke atas. Kedua, pasang Komposer untuk mengurus pakej pergantungan PHP. Akhir sekali, pasang alat baris arahan Hyperf hyperf/hyperf.
2. Cipta projek
Gunakan alat baris arahan Hyperf untuk mencipta projek baharu:
$ composer create-project hyperf/hyperf-skeleton
Arahan ini akan mencipta projek bernama hyperf-skeleton dalam direktori semasa. Masukkan direktori projek:
$ cd hyperf-skeleton
3. Bangunkan prototaip
Sebelum memulakan pembangunan formal, cipta prototaip untuk mengesahkan beberapa fungsi asas. Mula-mula anda boleh membuat UserController dan menambah antara muka pendaftaran:
<?php namespace AppController; use HyperfHttpServerAnnotationController; use HyperfHttpServerAnnotationPostMapping; /** * @Controller(prefix="/user") */ class UserController { /** * @PostMapping("/register") */ public function register() { // 注册逻辑 } }
Kemudian, daftarkan antara muka dalam fail konfigurasi penghalaan (routes.php):
use AppControllerUserController; Router::addGroup('/user', function () { Router::post('/register', [UserController::class, 'register']); });
Mulakan pelayan pembangunan Hyperf:
$ php bin/hyperf.php start
Gunakan alat seperti Posmen untuk menghantar Permintaan POST ke http://127.0.0.1:9501/user/register dan anda boleh melihat bahawa antara muka berfungsi seperti biasa.
4. Operasi Pangkalan Data
Dalam pembangunan perkhidmatan mikro sebenar, selalunya perlu untuk berinteraksi dengan pangkalan data. Hyperf menyediakan komponen Hyperf/Pangkalan Data untuk mengendalikan pangkalan data. Mula-mula, pasang komponen Hyperf/Pangkalan Data melalui Komposer:
$ composer require hyperf/database
Kemudian, konfigurasikan maklumat sambungan pangkalan data dalam fail .env:
DB_DRIVER=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=test DB_USERNAME=root DB_PASSWORD=
Seterusnya, konfigurasikan maklumat sambungan pangkalan data dalam fail config/autoload/databases.php:
return [ 'default' => [ 'driver' => env('DB_DRIVER', 'mysql'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', 3306), 'database' => env('DB_DATABASE', 'test'), 'username' => env('DB_USERNAME', 'root'), 'password' => env('DB_PASSWORD', ''), ], ];
Kemudian, Gunakan komponen Hyperf/Database dalam UserController untuk melaksanakan operasi pangkalan data:
<?php namespace AppController; use HyperfDbConnectionDb; use HyperfHttpServerAnnotationController; use HyperfHttpServerAnnotationPostMapping; /** * @Controller(prefix="/user") */ class UserController { /** * @PostMapping("/register") */ public function register() { $username = $this->request->input('username'); $password = $this->request->input('password'); // 插入用户数据 $userId = Db::table('users')->insertGetId([ 'username' => $username, 'password' => $password, ]); // 返回用户ID return $this->response->json(['user_id' => $userId]); } }
5. Langkah keselamatan
Dalam pembangunan perkhidmatan mikro, keselamatan adalah sangat penting. Hyperf menyediakan beberapa langkah keselamatan untuk melindungi aplikasi. Komponen Hyperf/Security boleh digunakan untuk menyulitkan dan menyahsulit data sensitif, serta menjana dan mengesahkan tandatangan.
Pasang komponen Hyperf/Security:
$ composer require hyperf/security
Konfigurasikan komponen Hyperf/Security dalam fail config/autoload/dependencies.php:
return [ 'dependencies' => [ // ... HyperfSecurityEncrypterInterface::class => HyperfSecurityHashPasswordHash::class, HyperfSecuritySecurityManagerInterface::class => HyperfSecuritySecurityManager::class, ], ];
Kemudian, gunakan komponen Hyperf/Security dalam UserController untuk menyulitkan dan menyahsulit data:
<?php namespace AppController; use HyperfDbConnectionDb; use HyperfHttpServerAnnotationController; use HyperfHttpServerAnnotationPostMapping; use HyperfSecurityEncrypterInterface; use HyperfSecuritySecurityManagerInterface; /** * @Controller(prefix="/user") */ class UserController { /** * @PostMapping("/register") */ public function register(EncrypterInterface $encrypter, SecurityManagerInterface $security) { $username = $this->request->input('username'); $password = $this->request->input('password'); // 加密密码 $hashedPassword = $security->passwordHash($password); // 插入用户数据 $userId = Db::table('users')->insertGetId([ 'username' => $username, 'password' => $hashedPassword, ]); // 使用加密算法生成令牌 $token = $encrypter->encrypt([ 'user_id' => $userId, 'username' => $username, ]); // 返回用户ID和令牌 return $this->response->json(['user_id' => $userId, 'token' => $token]); } }
$ php bin/hyperf.php vendor:publish hyperf/snowflake
$ php bin/hyperf.php vendor:publish hyperf/config
$ php bin/hyperf.php start
Atas ialah kandungan terperinci Amalan Terbaik Pembangunan Perkhidmatan Mikro PHP Hyperf: Dari Prototaip kepada Pengeluaran. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!