CakePHP - Konfigurasi Proyek
Dalam bab ini, kita akan memahami Environment Variables, General Configuration, Database Configuration dan Email Configuration di CakePHP.
ConfigurationCakePHP hadir dengan satu file konfigurasi secara default, dan kita dapat memodifikasinya sesuai kebutuhan kita. Ada satu folder khusus“config”untuk tujuan ini. CakePHP hadir dengan opsi konfigurasi yang berbeda.
Mari kita mulai dengan memahami Variabel Lingkungan di CakePHP.
Variabel Lingkungan
Variabel lingkungan memudahkan kerja aplikasi Anda di lingkungan yang berbeda. Misalnya, di server dev, server pengujian, server penahapan, dan lingkungan server produksi. Untuk semua lingkungan ini, Anda dapat memanfaatkanenv() function untuk membaca konfigurasi untuk lingkungan yang Anda butuhkan dan membangun aplikasi Anda.
Di folder config Anda, Anda akan menemukan config / .env.example. File ini memiliki semua variabel yang akan diubah berdasarkan lingkungan Anda. Untuk memulainya, Anda dapat membuat file di folder config yaitu config / .env dan menentukan variabel tersebut dan menggunakannya. Jika Anda memerlukan variabel tambahan, itu bisa masuk ke file itu.
Anda dapat membaca variabel lingkungan Anda menggunakan fungsi env () seperti yang ditunjukkan di bawah ini -
Contoh
$debug = env('APP_DEBUG', false);
Yang pertama adalah nama variabel lingkungan yang Anda inginkan dan nilai kedua adalah nilai default. Nilai default digunakan, jika tidak ada nilai yang ditemukan untuk variabel lingkungan.
Konfigurasi Umum
Tabel berikut menjelaskan peran berbagai variabel dan bagaimana pengaruhnya terhadap aplikasi CakePHP Anda.
Sr Tidak | Nama & Deskripsi Variabel |
---|---|
1 | debug Mengubah keluaran debugging CakePHP. false= Mode produksi. Tidak ada pesan kesalahan, kesalahan, atau peringatan yang ditampilkan. true = Kesalahan dan peringatan ditampilkan. |
2 | App.namespace Namespace untuk menemukan kelas aplikasi di bawah. |
3 | App.baseUrl Hapus komentar definisi ini, jika Anda tidak berencana menggunakan mod_rewrite Apache dengan CakePHP. Jangan lupa untuk menghapus file .htaccess Anda juga. |
4 | App.base Direktori dasar tempat aplikasi berada. Jika salah, ini akan otomatis terdeteksi. |
5 | App.encoding Tentukan pengkodean yang digunakan aplikasi Anda. Pengkodean ini digunakan untuk menghasilkan rangkaian karakter dalam tata letak, dan menyandikan entitas. Ini harus cocok dengan nilai pengkodean yang ditentukan untuk database Anda. |
6 | App.webroot Direktori webroot. |
7 | App.wwwRoot Jalur file ke webroot. |
8 | App.fullBaseUrl Nama domain yang sepenuhnya memenuhi syarat (termasuk protokol) ke root aplikasi Anda. |
9 | App.imageBaseUrl Jalur web ke direktori gambar publik di bawah webroot. |
10 | App.cssBaseUrl Jalur web ke direktori css publik di bawah webroot. |
11 | App.jsBaseUrl Jalur web ke direktori js publik di bawah webroot. |
12 | App.paths Konfigurasikan jalur untuk sumber daya berbasis non-kelas. Mendukungplugins, templates, locales, subkeys, yang memungkinkan definisi jalur untuk plugin, template tampilan dan file lokal masing-masing. |
13 | Security.salt String acak yang digunakan dalam hashing. Nilai ini juga digunakan sebagai salt HMAC saat melakukan enkripsi simetris. |
14 | Asset.timestamp Menambahkan stempel waktu, yaitu waktu terakhir diubah dari file tertentu di bagian akhir URL file aset (CSS, JavaScript, Gambar) saat menggunakan pembantu yang tepat. Nilai yang valid adalah -
|
Konfigurasi Database
Basis data dapat dikonfigurasi di config/app.php and config/app_local.phpmengajukan. File ini berisi koneksi default dengan parameter yang disediakan, yang dapat dimodifikasi sesuai pilihan kita.
Cuplikan di bawah ini menunjukkan parameter dan nilai default, yang harus dimodifikasi sesuai kebutuhan.
Config / app_local.php
*/
'Datasources' => [
'default' => [
'host' => 'localhost',
'username' => 'my_app',
'password' => 'secret',
'database' => 'my_app',
'url' => env('DATABASE_URL', null),
],
/*
* The test connection is used during the test suite.
*/
'test' => [
'host' => 'localhost',
//'port' => 'non_standard_port_number',
'username' => 'my_app',
'password' => 'secret',
'database' => 'test_myapp',
//'schema' => 'myapp',
],
],
Mari kita pahami setiap parameter secara detail di config/app_local.php.
Tuan rumah | Nama host server database (atau alamat IP). |
---|---|
nama pengguna | Nama pengguna database |
kata sandi | Kata sandi database. |
database | Nama Database. |
Pelabuhan | Port TCP atau soket Unix yang digunakan untuk menyambung ke server. |
config / app.php
'Datasources' => [
'default' => [
'className' => Connection::class,
'driver' => Mysql::class,
'persistent' => false,
'timezone' => 'UTC',
//'encoding' => 'utf8mb4',
'flags' => [],
'cacheMetadata' => true,
'log' => false,
'quoteIdentifiers' => false,
//'init' => ['SET GLOBAL innodb_stats_on_metadata = 0'],
],
]
Mari kita pahami setiap parameter secara detail di config/app.php.
catatanSr Tidak | Kunci & Deskripsi |
---|---|
1 | className Nama kelas dengan namespace lengkap dari kelas yang mewakili koneksi ke server database. Kelas ini bertanggung jawab untuk memuat driver database, menyediakan mekanisme transaksi SQL dan menyiapkan pernyataan SQL antara lain. |
2 | driver Nama kelas dari driver yang digunakan untuk mengimplementasikan semua spesifikasi untuk mesin database. Ini bisa berupa nama kelas pendek menggunakan sintaks plugin, nama dengan spasi penuh, atau instance driver yang dibuat. Contoh nama kelas pendek adalah Mysql, Sqlite, Postgres, dan Sqlserver. |
3 | persistent Apakah akan menggunakan koneksi persisten ke database atau tidak. |
4 | encoding Menunjukkan set karakter yang akan digunakan, saat mengirim pernyataan SQL ke server seperti 'utf8' dll. |
5 | timezone Zona waktu server untuk disetel. |
6 | init Daftar kueri yang harus dikirim ke server database saat dan saat koneksi dibuat. |
7 | log Setel ke true untuk mengaktifkan pencatatan kueri. Saat diaktifkan, kueri akan dicatat pada tingkat debug dengan cakupan queriesLog. |
8 | quoteIdentifiers Setel ke benar, jika Anda menggunakan kata khusus atau karakter khusus dalam nama tabel atau kolom Anda. Mengaktifkan setelan ini akan menghasilkan kueri yang dibuat menggunakan Query Builder memiliki pengenal yang dikutip saat membuat SQL. Ini menurunkan kinerja. |
9 | flags Array asosiatif dari konstanta PDO yang harus diteruskan ke instance PDO yang mendasarinya. |
10 | cacheMetadata Baik boolean true, atau string yang berisi konfigurasi cache untuk menyimpan meta data. Tidak disarankan untuk menonaktifkan cache metadata dan dapat mengakibatkan performa yang sangat buruk. |
Konfigurasi Email
Email dapat dikonfigurasi dalam file config/app.php. Tidak diperlukan untuk menentukan konfigurasi email di config / app.php. Email dapat digunakan tanpa itu. Cukup gunakan metode masing-masing untuk mengatur semua konfigurasi secara terpisah atau memuat berbagai konfigurasi. Konfigurasi untuk default Email dibuat menggunakanconfig() dan configTransport().
Transportasi Konfigurasi Email
Dengan menentukan pengangkutan secara terpisah dari profil pengiriman, Anda dapat dengan mudah menggunakan kembali konfigurasi pengangkutan di beberapa profil. Anda dapat menentukan beberapa konfigurasi untuk produksi, pengembangan, dan pengujian. Setiap transportasi membutuhkan className. Opsi yang valid adalah sebagai berikut -
Mail - Kirim menggunakan fungsi PHP mail
Smtp - Kirim menggunakan SMTP
Debug - Jangan kirim email, cukup kembalikan hasilnya
Anda dapat menambahkan transpor kustom (atau mengganti transpor yang ada) dengan menambahkan file yang sesuai ke src/Mailer/Transport. Transportasi harus diberi namaYourTransport.php, dimana 'Your' adalah nama transportasinya.
Berikut adalah contoh pengangkutan konfigurasi Email.
'EmailTransport' => [
'default' => [
'className' => 'Mail',
// The following keys are used in SMTP transports
'host' => 'localhost',
'port' => 25,
'timeout' => 30,
'username' => 'user',
'password' => 'secret',
'client' => null,
'tls' => null,
'url' => env('EMAIL_TRANSPORT_DEFAULT_URL', null),
],
],
Profil Pengiriman Email
Profil pengiriman memungkinkan Anda menentukan berbagai properti sebelumnya tentang pesan email dari aplikasi Anda, dan memberi nama pada pengaturan. Ini menghemat duplikasi di seluruh aplikasi Anda dan membuat pemeliharaan dan pengembangan lebih mudah. Setiap profil menerima sejumlah kunci.
Berikut adalah contoh profil pengiriman email.
'Email' => [
'default' => [
'transport' => 'default',
'from' => 'you@localhost',
],
],