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:
./vendor/bin/expressive module:create BlogIni 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
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', ], ], ], ]; }
run src/Blog/config/doctrine
ke BlogPost.orm.yml
. Kemudian jalankan arahan berikut untuk membuat jadual pangkalan data:
--- 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
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
./vendor/bin/doctrine orm:schema-tool:create
Modul ekspresif tidak secara langsung mendaftarkan laluan. Kita perlu menggunakan helah kecil untuk mencapainya: Buat fail
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.');, dengan kandungan berikut:
tambahkan kod berikut dalam
's
src/Blog/src/Factory/RoutesDelegator.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; } }fail dan tambahkan laluan blog:
src/Blog/src/ConfigProvider.php
getDependencies()
'delegators' => [ \Zend\Expressive\Application::class => [ Factory\RoutesDelegator::class, ], ],
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.)
<?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');
Pelaksanaan fungsi penciptaan, penyuntingan dan penghapusan dikhaskan untuk latihan.
Ringkasan
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
.
(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!

Untuk melindungi permohonan dari serangan XSS yang berkaitan dengan sesi, langkah-langkah berikut diperlukan: 1. Tetapkan bendera httponly dan selamat untuk melindungi kuki sesi. 2. Kod eksport untuk semua input pengguna. 3. Melaksanakan Dasar Keselamatan Kandungan (CSP) untuk mengehadkan sumber skrip. Melalui dasar-dasar ini, serangan XSS yang berkaitan dengan sesi dapat dilindungi dengan berkesan dan data pengguna dapat dipastikan.

Kaedah untuk mengoptimumkan prestasi sesi PHP termasuk: 1. Mula sesi kelewatan, 2. Gunakan pangkalan data untuk menyimpan sesi, 3. Data sesi kompres, 4. Mengurus kitaran hayat sesi, dan 5. Melaksanakan perkongsian sesi. Strategi ini dapat meningkatkan kecekapan aplikasi dalam persekitaran konkurensi yang tinggi.

Thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata, setInseconds.1) it'sconfiguredinphp.iniorviaini_set (). 2) abalanceisneededtoavoidperformanceissuesandunexpectedlogouts.3) php'sgarbageCollectionisprobabilistic, influedbygc_probabi

Dalam PHP, anda boleh menggunakan fungsi session_name () untuk mengkonfigurasi nama sesi. Langkah -langkah tertentu adalah seperti berikut: 1. Gunakan fungsi session_name () untuk menetapkan nama sesi, seperti session_name ("my_session"). 2. Selepas menetapkan nama sesi, hubungi session_start () untuk memulakan sesi. Mengkonfigurasi nama sesi boleh mengelakkan konflik data sesi antara pelbagai aplikasi dan meningkatkan keselamatan, tetapi memberi perhatian kepada keunikan, keselamatan, panjang dan penetapan masa sesi.

ID sesi hendaklah dijadikan semula secara teratur pada log masuk, sebelum operasi sensitif, dan setiap 30 minit. 1. Meningkatkan semula ID Sesi semasa log masuk untuk mengelakkan serangan tetap sesi. 2. Regenerate sebelum operasi sensitif untuk meningkatkan keselamatan. 3. Penjanaan semula secara berkala mengurangkan risiko penggunaan jangka panjang, tetapi pengalaman pengguna perlu ditimbang.

Menetapkan Parameter Cookie Sesi di PHP boleh dicapai melalui fungsi session_set_cookie_params (). 1) Gunakan fungsi ini untuk menetapkan parameter, seperti masa tamat, laluan, nama domain, bendera keselamatan, dan lain -lain; 2) hubungi session_start () untuk membuat parameter berkuatkuasa; 3) menyesuaikan parameter secara dinamik mengikut keperluan, seperti status log masuk pengguna; 4) Perhatikan untuk menetapkan bendera selamat dan httponly untuk meningkatkan keselamatan.

Tujuan utama menggunakan sesi dalam PHP adalah untuk mengekalkan status pengguna antara halaman yang berbeza. 1) Sesi dimulakan melalui fungsi session_start (), mewujudkan ID sesi yang unik dan menyimpannya dalam cookie pengguna. 2) Data sesi disimpan di pelayan, yang membolehkan data diluluskan antara permintaan yang berbeza, seperti status log masuk dan kandungan keranjang belanja.

Bagaimana untuk berkongsi sesi antara subdomain? Dilaksanakan dengan menetapkan kuki sesi untuk nama domain biasa. 1. Tetapkan domain cookie sesi ke .example.com di sebelah pelayan. 2. Pilih kaedah penyimpanan sesi yang sesuai, seperti memori, pangkalan data atau cache yang diedarkan. 3. Lulus ID Sesi melalui kuki, dan pelayan mengambil semula dan mengemas kini data sesi berdasarkan ID.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

Dreamweaver Mac版
Alat pembangunan web visual

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini