Rumah > rangka kerja php > Laravel > Adakah anda tahu cara menetapkan kebenaran direktori Laravel? (dua kaedah)

Adakah anda tahu cara menetapkan kebenaran direktori Laravel? (dua kaedah)

藏色散人
Lepaskan: 2021-11-02 15:40:31
ke hadapan
3251 orang telah melayarinya
Jika anda memberikan mana-mana folder 777 kebenaran, ia membenarkan sesiapa sahaja membaca, mengubah suai dan melaksanakan mana-mana fail dalam direktori. Ini bermakna anda telah memberi sesiapa sahaja (mana-mana penggodam atau orang yang berniat jahat di seluruh dunia) kebenaran untuk memuat naik mana-mana fail, virus atau mana-mana fail lain dan kemudian melaksanakan fail tersebut.

Jika anda menetapkan kebenaran folder anda kepada 777, maka anda telah membuka pelayan anda kepada sesiapa sahaja yang boleh mencari direktori itu. faham?

Bendera sesiapa sahaja bermaksud mana-mana pengguna, bukan sesiapa. Anda masih memerlukan akses pelayan.

Pada asasnya terdapat dua cara untuk menetapkan pemilikan dan kebenaran anda. Sama ada berikan diri anda pemilikan atau jadikan pelayan web pemilik semua fail.

[Cadangan berkaitan:

Lima tutorial video Laravel terbaharu]

Pelayan web sebagai pemilik (apa yang kebanyakan orang lakukan dan apa yang Laravel doc lakukan) :

Anggap

ialah pengguna perkhidmatan web anda (ia mungkin nama lain). www-data

sudo chown -R www-data:www-data /path/to/your/laravel/root/directory
Salin selepas log masuk
Jika anda melakukan ini, fail yang dimiliki oleh perkhidmatan web juga akan menjadi kumpulan ini, jadi terdapat beberapa masalah apabila anda menggunakan FTP untuk memuat naik fail, kerana klien FTP akan log masuk dengan anda akaun , bukan perkhidmatan web anda, jadi anda harus menambah pengguna anda pada kumpulan pengguna perkhidmatan web.

sudo usermod -a -G www-data ubuntu
Salin selepas log masuk
Sudah tentu, ini mengandaikan bahawa perkhidmatan web anda berjalan sebagai pengguna data-www (Homestead lalai), dan pengguna anda ialah ubuntu (atau gelandangan jika dalam Homestead). Kemudian tetapkan semua direktori anda kepada 755 dan semua fail anda kepada 644.

sudo find /path/to/your/laravel/root/directory -type f -exec chmod 644 {} \;
Salin selepas log masuk
Tetapkan kebenaran direktori

sudo find /path/to/your/laravel/root/directory -type d -exec chmod 755 {} \;
Salin selepas log masuk

Pengguna anda sebagai pemilik

Saya lebih suka memiliki semua direktori dan fail (ini memudahkan untuk mengendalikan apa sahaja), jadi, pergi ke direktori akar laravel:

cd /var/www/html/laravel >> assuming this is your current root directory
Salin selepas log masuk
sudo chown -R $USER:www-data .
Salin selepas log masuk
Kemudian saya memberi diri saya dan pelayan laman web dua kebenaran:

sudo find . -type f -exec chmod 664 {} \;   
sudo find . -type d -exec chmod 775 {} \;
Salin selepas log masuk

Kemudian berikan kebenaran membaca dan menulis pelayan web untuk penyimpanan dan caching

Tidak kira bagaimana anda menyediakannya, anda perlu memberikan kebenaran membaca dan menulis pelayan web untuk penyimpanan, caching dan pelayan web perlu muat naik atau tulis ke mana-mana direktori lain (bergantung pada kes anda), jadi jalankan arahan berikut:

sudo chgrp -R www-data storage bootstrap/cache
sudo chmod -R ug+rwx storage bootstrap/cache
Salin selepas log masuk
Kini, tapak web anda selamat dan anda boleh mengendalikan fail ini dengan mudah

Alamat asal: https://stackoverflow.com/questions/30639174/how-to-set-up-file-permissions-for-laravel

Alamat terjemahan: https://learnku .com/laravel/ t/62112

Atas ialah kandungan terperinci Adakah anda tahu cara menetapkan kebenaran direktori Laravel? (dua kaedah). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:learnku.com
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan