Rumah pembangunan bahagian belakang masalah PHP Cara menggunakan PHP untuk menyembunyikan laluan muat naik imej

Cara menggunakan PHP untuk menyembunyikan laluan muat naik imej

Apr 06, 2023 am 09:13 AM

PHP ialah bahasa pengaturcaraan yang digunakan secara meluas digunakan untuk membangunkan pelbagai jenis aplikasi web. Dalam proses pembangunan web, muat naik imej adalah keperluan biasa. Walau bagaimanapun, kadangkala kami ingin menyembunyikan laluan imej semasa memuat naiknya, kerana mendedahkan laluan itu mungkin memberi peluang kepada penggodam untuk menyerang. Dalam artikel ini, kami akan memperkenalkan cara menggunakan PHP untuk menyembunyikan laluan muat naik imej.

Pertama, kita perlu mencipta borang HTML yang membolehkan pengguna memilih imej untuk dimuat naik. Borang HTML biasanya mempunyai beberapa elemen, seperti kotak input jenis "fail" yang membolehkan pengguna memilih fail untuk dimuat naik. Kita boleh mencipta borang ini menggunakan beberapa kod HTML asas:

<form method="post" action="upload.php" enctype="multipart/form-data">
  <input type="file" name="image">
  <input type="submit" value="Upload">
</form>
Salin selepas log masuk

Dalam contoh ini, kami menetapkan atribut "tindakan" borang HTML kepada "upload.php", yang akan memberitahu skrip PHP kepada The data borang dihantar kepada pengendali skrip bernama "upload.php".

Seterusnya, kita perlu melaksanakan fungsi muat naik imej dalam skrip "upload.php". Gunakan fungsi "move_uploaded_file" dalam PHP untuk mengalihkan fail yang dimuat naik ke direktori yang ditentukan. Sebelum itu, kita boleh menggunakan fungsi "uniqid" PHP untuk menjana nama fail unik untuk fail yang dimuat naik. Ini hanyalah contoh kod mudah:

<?php
  $target_dir = "uploads/";
  $target_file = $target_dir . uniqid() . basename($_FILES["image"]["name"]);
  move_uploaded_file($_FILES["image"]["tmp_name"], $target_file);
  echo "The file has been uploaded.";
?>
Salin selepas log masuk

Dalam contoh ini, kami mengalihkan fail yang dimuat naik ke dalam direktori "muat naik". Nama fail akan menjadi rentetan unik dan akhiran dikekalkan. Ini akan memastikan bahawa nama fail kami adalah unik. Ambil perhatian bahawa dalam contoh ini kami menggunakan pernyataan "gema" untuk mengeluarkan mesej muat naik yang berjaya. Jika anda mahukan lebih banyak interaksi, anda boleh menghantarnya ke halaman lain.

Walau bagaimanapun, terdapat beberapa risiko di sini. Secara lalai, pengguna boleh mengakses laluan imej dengan melihat kod sumber halaman atau memasukkan laluan imej dalam penyemak imbas. Untuk menyelesaikan masalah ini, kami boleh menyimpan imej di lokasi di luar direktori web dan kemudian membacanya dengan PHP.

Kita boleh menggunakan fungsi "file_get_contents" PHP untuk membaca fail dan fungsi "header" PHP untuk menetapkan pengepala Jenis Kandungan. Di bawah ialah kod yang telah diedit.

<?php
  $file_path = "uploads/" . uniqid() . basename($_FILES["image"]["name"]);
  move_uploaded_file($_FILES["image"]["tmp_name"], $file_path);
  header(&#39;Content-Type: &#39;. mime_content_type($file_path));
  echo file_get_contents($file_path);
  unlink($file_path);
?>
Salin selepas log masuk

Dalam contoh ini, kami menetapkan nama fail kepada rentetan unik dan menyimpannya dalam direktori "muat naik". Kami kemudian menetapkan pengepala Jenis Kandungan menggunakan fungsi "header" PHP dan membaca kandungan fail menggunakan fungsi "file_get_contents" PHP. Akhir sekali, kami memadamkan fail menggunakan fungsi "nyahpaut" PHP. Memandangkan PHP menggunakan nama fail TMP, penyemak imbas tidak akan terjejas walaupun selepas memadamkan fail.

Ringkasnya, menyembunyikan laluan muat naik imej dalam PHP ialah langkah keselamatan yang sangat penting yang membantu melindungi aplikasi anda daripada serangan. Menggunakan teknik di atas, anda boleh menyembunyikan laluan imej dengan mudah dan melindungi aplikasi web anda daripada penggodam.

Atas ialah kandungan terperinci Cara menggunakan PHP untuk menyembunyikan laluan muat naik imej. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Bagaimana untuk menggunakan tugas-tugas asynchronous dalam PHP untuk operasi tidak menyekat? Mar 10, 2025 pm 04:21 PM

Artikel ini meneroka pelaksanaan tugas tak segerak dalam PHP untuk meningkatkan respons aplikasi web. Ia memperincikan kaedah seperti beratur mesej, rangka kerja asynchronous (reactphp, swoole), dan proses latar belakang, menekankan amalan terbaik untuk kecekapan

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. PHP 8 JIT (Just-in-Time) Penyusunan: Bagaimana ia meningkatkan prestasi. Mar 25, 2025 am 10:37 AM

Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Bagaimana cara menggunakan teknik pengoptimuman memori dalam PHP? Mar 10, 2025 pm 04:23 PM

Artikel ini menangani pengoptimuman memori PHP. IT memperincikan teknik seperti menggunakan struktur data yang sesuai, mengelakkan penciptaan objek yang tidak perlu, dan menggunakan algoritma yang cekap. Sumber kebocoran memori biasa (mis., Sambungan yang tidak terkawal, global v

Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Bagaimanakah saya tetap up-to-date dengan ekosistem dan komuniti php? Mar 10, 2025 pm 06:16 PM

Artikel ini meneroka strategi untuk kekal semasa dalam ekosistem PHP. Ia menekankan penggunaan saluran rasmi, forum komuniti, persidangan, dan sumbangan sumber terbuka. Penulis menyoroti sumber terbaik untuk mempelajari ciri -ciri baru dan a

See all articles