Rumah >pembangunan bahagian belakang >tutorial php >Perkembangan pesat modul ekspresif zend

Perkembangan pesat modul ekspresif zend

Jennifer Aniston
Jennifer Anistonasal
2025-02-09 08:35:12641semak imbas

Rapid Development of Zend Expressive Modules

Zend Expressive Module Panduan Pembangunan Pantas: Membina Modul Blog Baca sahaja

Artikel ini akan berkongsi beberapa petua pembangunan modul Ekspresif Zend untuk membantu anda dengan cepat membina modul blog baca sahaja berfungsi sepenuhnya. Pastikan anda telah menyediakan persekitaran pembangunan mengikut tutorial terdahulu, termasuk memasang dan mengkonfigurasi Zend Expressive, Doctrine, Gulp dan Abstrak Reflection Factory (kira -kira 10 minit).

Dalam tutorial ini, kami dengan cepat akan membina modul blog baca sahaja yang mudah (senarai catatan blog dari pangkalan data) untuk menunjukkan keupayaan pembangunan pesat Zend Expressive.

Tetapan modul

Jalankan arahan berikut dalam aplikasi ekspresif anda:

<code class="language-bash">./vendor/bin/expressive module:create Blog</code>
Ini akan menghasilkan kod asas modul blog dan mendaftarkannya secara automatik dalam aplikasi anda dan Autoloader komposer.

Entiti Doktrin dan Jadual Pangkalan Data

Seterusnya, buat entiti blog dan jadual pangkalan data. Pertama, kita perlu membiarkan permohonan mengetahui bahawa modul menyediakan entiti doktrin.

buka

dan tambahkan kod berikut: src/Blog/src/ConfigProvider.php

3
<code class="language-php">public function __invoke()
{
    return [
        'dependencies' => $this->getDependencies(),
        'doctrine'     => $this->getDoctrine(),
        'templates'    => $this->getTemplates(),
    ];
}

public function getDoctrine(): array
{
    return [
        'driver' => [
            'orm_default' => [
                'drivers' => [
                    'Blog\Entity' => 'blog_entity',
                ],
            ],
            'blog_entity' => [
                'class' => \Doctrine\ORM\Mapping\Driver\SimplifiedYamlDriver::class,
                'cache' => 'array',
                'paths' => [
                    dirname(__DIR__) . '/config/doctrine' => 'Blog\Entity',
                ],
            ],
        ],
    ];
}</code>

run . Oleh kerana doktrin tidak menyokong struktur direktori piawai PSR-4, adalah perlu untuk bergerak src/Blog/config/doctrine ke BlogPost.orm.yml. Kemudian jalankan arahan berikut untuk membuat jadual pangkalan data:

<code class="language-yaml">---
Blog\Entity\BlogPost:
  type: entity
  table: blog_post
  id:
    id:
      type: integer
      generator:
        strategy: AUTO
  fields:
    title:
      type: string
      length: 255
    content:
      type: string
      length: 16777215</code>

anda boleh menjalankan pernyataan SQL berikut untuk mengisi jadual pangkalan data: ./vendor/bin/doctrine orm:generate-entities src src/Blog/Entity src/Blog/src/Entity

Tetapan Laluan
<code class="language-bash">./vendor/bin/doctrine orm:schema-tool:create</code>

Modul ekspresif tidak secara langsung mendaftarkan laluan. Kita perlu menggunakan helah kecil untuk mencapainya: Buat fail
<code class="language-sql">INSERT INTO expressive.blog_post VALUES 
(null, 'Post 1', 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'),
(null, 'Post 2', 'Mauris in libero laoreet, euismod lorem eget, tincidunt justo.'),
(null, 'Post 3', 'Donec sed diam congue, ultrices tellus at, venenatis felis.');</code>
, dengan kandungan berikut:

tambahkan kod berikut dalam

's > Kaedah:

src/Blog/src/Factory/RoutesDelegator.php

Buat
<code class="language-php"><?php
namespace Blog\Factory;

use Blog\Action;
use Psr\Container\ContainerInterface;
use Zend\Expressive\Application;

class RoutesDelegator
{
    public function __invoke(ContainerInterface $container, $serviceName, callable $callback)
    {
        $app = $callback();
        include __DIR__ . '/../../config/routes.php';
        return $app;
    }
}</code>
fail dan tambahkan laluan blog:

src/Blog/src/ConfigProvider.php getDependencies()

Tindakan dan templat
<code class="language-php">'delegators' => [
    \Zend\Expressive\Application::class => [
        Factory\RoutesDelegator::class,
    ],
],</code>

src/Blog/config/routes.php Seterusnya, buat tindakan untuk mengendalikan permintaan penghalaan dan buat fail templat. (Kod tindakan dan templat adalah sama dengan teks asal, yang ditinggalkan di sini, sila rujuk teks asal.)

<code class="language-php"><?php

use Blog\Action;

$app->get('/blog', Action\BlogPostListAction::class, 'blog_post_list');
$app->get('/blog/view/:blog_post_id', Action\BlogPostViewAction::class, 'blog_post_view');</code>

Pelaksanaan fungsi penciptaan, penyuntingan dan penghapusan dikhaskan untuk latihan.

Ringkasan

Rapid Development of Zend Expressive Modules Tutorial ini menunjukkan kemudahan dengan cepat membina modul blog baca sahaja dengan Zend Expressive. Dengan hanya beberapa fail dan beberapa minit kerja, anda boleh membuat halaman senarai yang memaparkan artikel dari pangkalan data dan bersedia untuk penambahan berikutnya seperti

dan

.

(Berikut adalah bahagian FAQ asal, sedikit diselaraskan)

/edit Zend Expressive Rapid Development FAQ /delete

  • Apakah Zend Expressive? Zend Expressive adalah rangka kerja middeware mini berasaskan PHP yang dibina di atas ketegangan Zend dan menyokong middleware PSR-7.

  • Bagaimana untuk memasang Zend Expressive? menggunakan komposer: composer require zendframework/zend-expressive

  • Kelebihan Zend Expressive? Perkembangan pesat, mudah dan fleksibel, menyokong pelbagai jenis aplikasi (microservices ke aplikasi tunggal badan), dan menyokong pelbagai sistem penghalaan dan templat.

  • Bagaimana untuk membuat modul dalam Zend Expressive? Buat direktori baru di bawah direktori aplikasi, termasuk kelas src, dan mengembalikan array konfigurasi modul (termasuk kebergantungan, laluan, dan templat). ConfigProvider

  • Bagaimana untuk menambah laluan di Zend Expressive? Tambahkan entri baru dalam kekunci dari pelbagai konfigurasi modul ConfigProvider kelas. routes

  • Bagaimana menggunakan templat dalam Zend Expressive? Zend Expressive menyokong pelbagai enjin templat (ranting, plat, pandangan zend). Tambah entri dalam kunci dari pelbagai konfigurasi kelas ConfigProvider. templates

  • Bagaimana menangani kesilapan dalam Zend Expressive? Zend Expressive mengandungi ralat lalai pengendalian middleware. Anda boleh membuat middleware tersuai untuk mengendalikan kesilapan.

  • Bagaimana untuk menguji aplikasi ekspresif zend? Gunakan phpunit.

  • Bagaimana untuk menggunakan aplikasi ekspresif Zend? menggunakan seperti aplikasi PHP yang lain, anda boleh menggunakan pelayan Apache, Nginx, atau PHP.

  • Di mana saya boleh mendapatkan lebih banyak sumber mengenai Zend Expressive? laman web rasmi Zend Framework, Dokumentasi Ekspresif Zend dan Forum Komuniti Rangka Kerja Zend.

Atas ialah kandungan terperinci Perkembangan pesat modul ekspresif zend. 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