Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Amalan Terbaik Pembangunan Perkhidmatan Mikro PHP Hyperf: Dari Prototaip kepada Pengeluaran

Amalan Terbaik Pembangunan Perkhidmatan Mikro PHP Hyperf: Dari Prototaip kepada Pengeluaran

WBOY
WBOYasal
2023-09-12 10:36:11795semak imbas

PHP Hyperf微服务开发最佳实践:从原型到生产环境

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]);
    }
}

Enam , Penggunaan persekitaran pengeluaran

Apabila pembangunan selesai, projek itu boleh digunakan ke persekitaran pengeluaran. Hyperf menyediakan beberapa arahan mudah untuk penggunaan, seperti arahan berikut untuk menjana cache laluan:

$ php bin/hyperf.php vendor:publish hyperf/snowflake

Konfigurasi boleh dimuat semula melalui arahan berikut:

$ php bin/hyperf.php vendor:publish hyperf/config

Akhir sekali, gunakan arahan berikut untuk memulakan pelayan persekitaran pengeluaran:

$ php bin/hyperf.php start

Itu sahaja amalan terbaik untuk pembangunan perkhidmatan mikro PHP Hyperf daripada prototaip kepada pengeluaran. Saya harap artikel ini dapat membantu pemula dan boleh memainkan peranan dalam pembangunan perkhidmatan mikro.

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn