Dalam pembangunan aplikasi Laravel, muat naik fail adalah operasi yang sangat biasa. Laravel menyediakan cara yang sangat mudah untuk mengurus fail yang dimuat naik ini, iaitu sistem fail. Sistem fail sebenarnya ialah kaedah storan lalai Laravel, dan ia menyimpan fail yang dimuat naik ke lokasi tertentu pada cakera.
Walau bagaimanapun, dalam beberapa kes, kami mungkin perlu menyimpan fail yang dimuat naik di lokasi lain, seperti storan awan, CDN atau perkhidmatan storan jauh yang lain. Pada masa ini, kita perlu mengubah suai kaedah storan lalai Laravel supaya ia boleh menyesuaikan diri dengan keperluan kita.
Artikel ini akan memperkenalkan cara mengubah suai storan lalai dalam Laravel untuk menyesuaikan diri dengan pelbagai senario.
1. Sistem fail Laravel
Dalam Laravel, sistem fail digunakan untuk mengurus fail dan direktori. Sistem fail Laravel termasuk beberapa operasi asas, seperti mencipta fail, membaca fail, mengemas kini fail dan memadam fail.
Sistem fail Laravel boleh menggunakan berbilang cakera untuk storan, termasuk cakera tempatan, storan awan seperti S3, storan FTP, dsb.
Kami boleh mengkonfigurasi sistem fail Laravel dalam fail konfigurasi config/filesystems.php:
<?php return [ 'default' => 'local', 'disks' => [ 'local' => [ 'driver' => 'local', 'root' => storage_path('app'), ], 'public' => [ 'driver' => 'local', 'root' => storage_path('app/public'), 'url' => env('APP_URL').'/storage', 'visibility' => 'public', ], 's3' => [ 'driver' => 's3', 'key' => env('AWS_ACCESS_KEY_ID'), 'secret' => env('AWS_SECRET_ACCESS_KEY'), 'region' => env('AWS_DEFAULT_REGION'), 'bucket' => env('AWS_BUCKET'), 'url' => env('AWS_URL'), ], ], ];
Dalam kod di atas, kita dapat melihat bahawa tiga jenis cakera dikonfigurasikan di sini: cakera tempatan (tempatan), cakera awam (awam) dan storan awan S3 (s3).
2. Ubah suai storan lalai
Dalam Laravel, kita boleh menggunakan kelas Storan untuk mengurus sistem fail. Secara lalai, Laravel akan menggunakan cakera tempatan sebagai lokasi storan sistem fail lalai ini ditakrifkan dalam config/filesystems.php dan nilai lalai adalah setempat.
Kami boleh mengubah suai item konfigurasi lalai config/filesystems.php untuk mengubah suai storan lalai:
<?php return [ 'default' => env('FILESYSTEM_DRIVER', 'local'), 'disks' => [ 'local' => [ 'driver' => 'local', 'root' => storage_path('app'), ], 'public' => [ 'driver' => 'local', 'root' => storage_path('app/public'), 'url' => env('APP_URL').'/storage', 'visibility' => 'public', ], 's3' => [ 'driver' => 's3', 'key' => env('AWS_ACCESS_KEY_ID'), 'secret' => env('AWS_SECRET_ACCESS_KEY'), 'region' => env('AWS_DEFAULT_REGION'), 'bucket' => env('AWS_BUCKET'), 'url' => env('AWS_URL'), ], ], ];
Dalam kod di atas, kami menukar nilai lalai daripada setempat kepada env(' FILESYSTEM_DRIVER ', 'local'). Fungsi env digunakan di sini, yang membolehkan kami mentakrifkan pembolehubah persekitaran FILESYSTEM_DRIVER dalam fail .env untuk mengubah suai storan lalai.
Sebagai contoh, jika anda mentakrifkan FILESYSTEM_DRIVER=s3 dalam fail .env, maka apabila menggunakan sistem fail Storan, Laravel akan menggunakan cakera s3 sebagai lokasi storan sistem fail lalai.
3. Gunakan storan tersuai
Selain mengubah suai storan lalai, kami juga boleh mengkonfigurasi storan tersuai untuk memenuhi keperluan khas kami.
Pertama, kita perlu mencipta pemacu storan baharu. Dalam direktori apl, buat direktori baharu yang dipanggil Storan, dan kemudian buat kelas baharu dalam direktori itu.
Sebagai contoh, jika kita ingin mencipta pemacu storan bernama Hadoop, maka kita boleh mencipta kelas bernama HadoopDriver:
<?php namespace App\Storage; use Illuminate\Filesystem\FilesystemAdapter; use Illuminate\Support\Facades\Storage; use Illuminate\Support\ServiceProvider; class HadoopDriverServiceProvider extends ServiceProvider { public function boot() { Storage::extend('hadoop', function ($app, $config) { // 返回一個實現(xiàn)了 FilesystemAdapter 接口的類 return new HadoopFileSystemAdapter($config); }); } } class HadoopFileSystemAdapter implements FilesystemAdapter { // 實現(xiàn) FilesystemAdapter 接口的方法 }
Dalam kod di atas, kami mentakrifkan kelas HadoopDriverServiceProvider , dalam kaedah but, pemacu storan baharu bernama hadoop didaftarkan.
Kemudian, kami mentakrifkan kelas HadoopFileSystemAdapter, yang melaksanakan semua kaedah antara muka FilesystemAdapter. Kaedah ini akan dipanggil apabila kami menggunakan sistem fail Storan untuk melaksanakan pelbagai operasi pada sistem fail, seperti mencipta fail, membaca fail, mengemas kini fail, memadam fail, dsb.
Akhir sekali, kita perlu mendaftarkan kelas HadoopDriverServiceProvider yang dibuat di atas ke dalam aplikasi Laravel. Ini boleh dilakukan dengan menambah kelas HadoopDriverServiceProvider dalam tatasusunan penyedia fail config/app.php:
<?php return [ // 省略其它代碼 'providers' => [ // 省略其它服務提供者 /* * 注冊 Hadoop 存儲驅(qū)動 */ \App\Storage\HadoopDriverServiceProvider::class, ], ];
4 Menggunakan storan tersuai
Menggunakan storan tersuai memerlukan memanggil kaedah storan dan Tentukan laluan storan. Sebagai contoh, jika kita ingin menggunakan storan tersuai bernama hadoop, kita boleh menggunakannya seperti ini:
use Illuminate\Support\Facades\Storage; Storage::disk('hadoop')->put('file.txt', $content);
Dalam kod di atas, kami menggunakan kaedah cakera untuk menentukan storan untuk digunakan, menyatakannya sebagai hadoop. Kami kemudian menggunakan kaedah put untuk menulis kandungan $content ke fail file.txt pada sistem fail.
Ringkasan
Dalam pembangunan aplikasi Laravel, muat naik dan penyimpanan fail adalah keperluan yang sangat biasa. Laravel menyediakan sistem fail yang berkuasa untuk mengurus operasi ini, dan juga membolehkan kami mengubah suai lokasi storan sistem fail lalai mengikut keperluan kami sendiri, malah mencipta pemacu storan tersuai untuk memenuhi keperluan khas. Ciri-ciri ini sangat meningkatkan fleksibiliti dan kebolehskalaan aplikasi.
Atas ialah kandungan terperinci laravel mengubah suai storan lalai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

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

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

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

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

TowOrkeffectivyWithPivotTableSinlaravel, firstAccessPivotDataingWithPivot () orwithTimestamps (), thenupdateEntriesWithupdatee XistingPivot (), ManagerelationshipSviadetach () andSync (), AnduseCustompivotModelSwhenneeded.1.usewithPivot () toincludespecificcol

Pengoptimuman prestasi Laravel dapat meningkatkan kecekapan aplikasi melalui empat arah teras. 1. Gunakan mekanisme cache untuk mengurangkan pertanyaan pendua, menyimpan data yang jarang berubah melalui cache :: ingat () dan kaedah lain untuk mengurangkan kekerapan akses pangkalan data; 2. Mengoptimumkan pangkalan data dari model ke pernyataan pertanyaan, elakkan pertanyaan n 1, menentukan pertanyaan medan, menambah indeks, pemprosesan paging dan pemisahan membaca dan menulis, dan mengurangkan kesesakan; 3. Gunakan operasi yang memakan masa seperti menghantar e-mel dan mengeksport fail ke pemprosesan asynchronous giliran, gunakan penyelia untuk menguruskan pekerja dan menubuhkan mekanisme semula; 4. Gunakan middleware dan penyedia perkhidmatan dengan munasabah untuk mengelakkan logik kompleks dan kod permulaan yang tidak perlu, dan kelewatan pemuatan perkhidmatan untuk meningkatkan kecekapan permulaan.

Laravelsanctum sesuai untuk pensijilan API yang sederhana dan ringan seperti SPA atau aplikasi mudah alih, manakala pasport sesuai untuk senario di mana fungsi OAuth2 penuh diperlukan. 1. Sanctum menyediakan pengesahan berasaskan token, sesuai untuk pelanggan pihak pertama; 2. Pasport menyokong proses kompleks seperti kod kebenaran dan kelayakan pelanggan, sesuai untuk pemaju pihak ketiga untuk mengakses; 3. Pemasangan dan konfigurasi Sanctum adalah lebih mudah dan kos penyelenggaraan adalah rendah; 4. Fungsi pasport adalah komprehensif tetapi konfigurasi adalah kompleks, sesuai untuk platform yang memerlukan kawalan kebenaran yang baik. Apabila memilih, anda harus menentukan sama ada ciri OAuth2 diperlukan berdasarkan keperluan projek.

Kaedah untuk menguruskan keadaan pangkalan data dalam ujian Laravel termasuk menggunakan refreshDatabase, pembenihan data selektif, penggunaan transaksi yang teliti, dan pembersihan manual jika perlu. 1. Gunakan RefreshDatabaseTrait untuk secara automatik memindahkan struktur pangkalan data untuk memastikan setiap ujian didasarkan pada pangkalan data yang bersih; 2. Gunakan benih tertentu untuk mengisi data yang diperlukan dan menghasilkan data dinamik dalam kombinasi dengan kilang model; 3. Gunakan DatabaseTransactionsTrait untuk melancarkan perubahan ujian, tetapi perhatikan batasannya; 4. Kaedah ini dipilih secara fleksibel mengikut jenis ujian dan persekitaran untuk memastikan kebolehpercayaan dan kecekapan ujian.

Laravel memudahkan pemprosesan transaksi pangkalan data dengan sokongan terbina dalam. 1. Gunakan kaedah DB :: Transaksi () untuk melakukan operasi secara automatik atau rollback untuk memastikan integriti data; 2. Sokongan urus niaga bersarang dan melaksanakannya melalui SavePoints, tetapi biasanya disyorkan untuk menggunakan pembungkus transaksi tunggal untuk mengelakkan kerumitan; 3. Menyediakan kaedah kawalan manual seperti begIntransaction (), komit () dan rollback (), sesuai untuk senario yang memerlukan pemprosesan yang lebih fleksibel; 4. Amalan terbaik termasuk menjaga urus niaga pendek, hanya menggunakannya apabila perlu, menguji kegagalan, dan merakam maklumat rollback. Kaedah pengurusan transaksi yang rasional dapat membantu meningkatkan kebolehpercayaan aplikasi dan prestasi.

Inti mengendalikan permintaan dan respons HTTP di Laravel adalah untuk menguasai pengambilalihan data permintaan, pulangan tindak balas dan muat naik fail. 1. Apabila menerima data permintaan, anda boleh menyuntik contoh permintaan melalui jenis petikan dan menggunakan input () atau kaedah sihir untuk mendapatkan medan, dan menggabungkan mengesahkan () atau membentuk kelas permintaan untuk pengesahan; 2. REBAT RESPONSE menyokong rentetan, pandangan, JSON, respons dengan kod status dan tajuk dan operasi redirect; 3. Apabila memproses fail muat naik, anda perlu menggunakan kaedah fail () dan simpan () untuk menyimpan fail. Sebelum memuat naik, anda perlu mengesahkan jenis dan saiz fail, dan laluan penyimpanan boleh disimpan ke pangkalan data.

Cara yang paling biasa untuk menjana laluan yang dinamakan di Laravel adalah menggunakan fungsi penolong laluan (), yang secara automatik sepadan dengan laluan berdasarkan nama laluan dan mengendalikan parameter mengikat. 1. Lulus nama laluan dan parameter dalam pengawal atau pandangan, seperti laluan ('user.profile', ['id' => 1]); 2. Apabila pelbagai parameter, anda hanya perlu lulus array, dan perintah itu tidak menjejaskan padanan, seperti laluan ('user.post.show', ['id' => 1, 'postid' => 10]); 3. Pautan boleh dibenamkan secara langsung dalam templat bilah, seperti melihat maklumat; 4. Apabila parameter pilihan tidak disediakan, mereka tidak dipaparkan, seperti laluan ('user.post',

Keutamaan barisan Laravel dikawal melalui urutan permulaan. Langkah -langkah tertentu ialah: 1. Tentukan pelbagai giliran dalam fail konfigurasi; 2. Tentukan keutamaan giliran apabila memulakan pekerja, seperti phpartisanqueue: kerja-queue = tinggi, lalai; 3. Gunakan kaedah onqueue () untuk menentukan nama giliran apabila mengedarkan tugas; 4. Gunakan Laravelhorizon dan alat lain untuk memantau dan mengurus prestasi barisan. Ini memastikan bahawa tugas-tugas keutamaan yang tinggi diproses terlebih dahulu sambil mengekalkan kestabilan kod dan kestabilan sistem.
