PHP File Upload
- ກັບໄປຕໍ່ຫລັງ PHP ການສ້າງ/ຂຽນບັນນາດ
- ກັບໄປຕໍ່ຫລັງ PHP Cookies
ຜ່ານ PHP, ຈະສາມາດນຳໃຊ້ບັນຊີວັດຖຸຂົນສົ່ງໄປຫາທີ່ບໍລິຫານ.
ສ້າງການສັນຍາການນຳໃຊ້ບັນຊີວັດຖຸ
ການອະນຸຍາດຜູ້ນຳໃຊ້ຂັບໄລຍະວັດຖຸຈະມີປະໂຫຍດຫລາຍ.
ບໍ່ມີຫຍັງທີ່ຂ້ອຍຕ້ອງການຫຍັງ HTML ທີ່ຈະນຳໃຊ້ສຳລັບການນຳໃຊ້ບັນຊີເພື່ອຂົນສົ່ງບັນຊີ:
<html> <body> <form action="upload_file.php" method="post" enctype="multipart/form-data"> <label for="file">Filename:</label> <input type="file" name="file" id="file" /> <br /> <input type="submit" name="submit" value="Submit" /> </form> </body> </html>
ບໍ່ມີຫຍັງທີ່ຂ້ອຍຕ້ອງການຫຍັງບັນຊີນີ້:
ລະຫັດ enctype ຂອງ ບັນຊີ <form> ອະນຸຍາດວ່າຈະນຳໃຊ້ທາງທີ່ໃຊ້ໃນການສົ່ງບັນຊີ. ໃນກໍລະນີທີ່ບັນຊີຕ້ອງມີຂໍ້ມູນສອງລະບົບ, ເຊັ່ນຂໍ້ມູນບັນຊີ, ບໍ່ຕ້ອງອະນຸຍາດ "multipart/form-data".
ລະຫັດ type="file" ຂອງ ບັນຊີ <input> ອະນຸຍາດວ່າຈະນຳໃຊ້ບັນຊີຄືບັນຊີ. ຕົວຢ່າງ, ເມື່ອພິມຕະບັນພາບໃນບູຣີເຊີ, ຈະເຫັນບັນຊີທີ່ພາຍໃຕ້ບັນຊີຂອງການກວດສອບ.
ຄວາມຄິດ:ການອະນຸຍາດຜູ້ນຳໃຊ້ຂັບໄລຍະວັດຖຸແມ່ນເປັນຄວາມອັນຕະລາຍຫລາຍ. ບໍ່ຕ້ອງອະນຸຍາດຜູ້ນຳໃຊ້ຄວນຂັດຂ້ອຍພຽງແຕ່ຜູ້ນຳໃຊ້ທີ່ເປັນຄວນ.
ສ້າງການສັນຍາການນຳໃຊ້ບັນຊີ
ໂດຍບໍ່ມີຫຍັງ "upload_file.php" ບັນຊີມີລະຫັດການນຳໃຊ້ສາຍການທີ່ຈະນຳໄປກັບການນຳໃຊ້ບັນຊີເພື່ອຂົນສົ່ງບັນຊີ:
<?php if ($_FILES["file"]["error"] > 0) { echo "ຄວາມຜິດ: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "ບັນທຶກໃນ: " . $_FILES["file"]["tmp_name"]; } ?>
ທັງສະບັບ PHP $_FILES, ທ່ານສາມາດນຳສົ່ງບົດຄວາມຈາກຄອມພິວເຕີ້ລູກຄ້າຫາທະນາຄານຫ່າງໄກ.
ປະເພດທໍາອິດແມ່ນຊື່ input form, ປະເພດທີສອງສາມາດແມ່ນ "name", "type", "size", "tmp_name" ຫຼື "error". ຄືດັ່ງກ່າວ:
- $_FILES["file"]["name"] - ຊື່ບົດຄວາມທີ່ຖືກນຳສົ່ງ
- $_FILES["file"]["type"] - ຊະນິດບົດຄວາມທີ່ຖືກນຳສົ່ງ
- $_FILES["file"]["size"] - ຂະໜາດບົດຄວາມທີ່ຖືກນຳສົ່ງ, ທີ່ມີຄວາມນ້ອຍທີ່ເວລາ
- $_FILES["file"]["tmp_name"] - ຊື່ບົດຄວາມຊອບຊ້ອນຄວາມທີ່ຢູ່ໃນທະນາຄານ
- $_FILES["file"]["error"] - ລະບັນຍາບັນຂອງຄວາມຜິດທີ່ເກີດຈາກການນຳສົ່ງບົດຄວາມ
ນີ້ແມ່ນວິທີການນຳສົ່ງບົດຄວາມທີ່ຫຼາກຫຼາຍ. ສຳລັບຄວາມຄິດເຫັນຄວາມປອດໄພ, ທ່ານຄວນເພີ່ມການຈຳກັດການທີ່ຜູ້ນຳໃຊ້ມີສິດຂອງການນຳສົ່ງບົດຄວາມ.
ການຈຳກັດການນຳສົ່ງ
ໃນບົດສະບັບນີ້, ພວກເຮົາໄດ້ເພີ່ມການຈຳກັດການນຳສົ່ງບົດຄວາມ. ຜູ້ນຳໃຊ້ພຽງແຕ່ສາມາດນຳສົ່ງ .gif ຫຼື .jpeg, ຂະໜາດບົດຄວາມຕ້ອງຕ້ອງຊົງກວ່າ 20 kb:
<?php if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/pjpeg")) && ($_FILES["file"]["size"] < 20000)) { if ($_FILES["file"]["error"] > 0) { echo "ຄວາມຜິດ: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "ບັນທຶກໃນ: " . $_FILES["file"]["tmp_name"]; } } else { echo "Invalid file"; } ?>
ຄວາມຄິດ:ສຳລັບ IE, ການຮັບຮູ້ຊະນິດຂອງບົດຄວາມ jpg ຕ້ອງເປັນ pjpeg, ສຳລັບ FireFox, ຕ້ອງເປັນ jpeg.
ການຮັບຮອງບົດຄວາມທີ່ຖືກນຳສົ່ງມາ
ຕົວຢ່າງຂອງພວກເຮົາສະແດງວ່າບົດຄວາມທີ່ຖືກນຳສົ່ງມາຈະຖືກສ້າງຄູ່ມັນຊອບຊ້ອນຄວາມທີ່ຢູ່ໃນສາຍຄູ່ມັນຊອບຊ້ອນຂອງ PHP ຂອງທະນາຄານ:
ບົດຄວາມຊອບຊ້ອນນີ້ຈະຫາຍໄປຫຼັງຈາກການດຳເນີນງານສະບັບສັນຍາວິດີອັນຈະຍາການການຮັບຮອງບົດຄວາມທີ່ຖືກນຳສົ່ງມາຕອບຢູ່ບ່ອນອື່ນໆ:
<?php if ((($_FILES["file"]["type"] == "image/gif") || ($_FILES["file"]["type"] == "image/jpeg") || ($_FILES["file"]["type"] == "image/pjpeg")) && ($_FILES["file"]["size"] < 20000)) { if ($_FILES["file"]["error"] > 0) { echo "ລະບັນຍາບັນ: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />"; if (file_exists("upload/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " already exists. "; } else { move_uploaded_file($_FILES["file"]["tmp_name"], echo "upload/" . $_FILES["file"]["name"]; echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; } } } else { echo "Invalid file"; } ?>
ບົດສະຫລຸບທີ່ກ່າວກ່ຽວກັບບັນດາບັນນາດທີ່ມີຢູ່ຂອງບັນດາບັນນາດ. ຖ້າບໍ່ມີ, ບັນດາບັນນາດຈະຖືກສໍາຮອງໄປສາຍທີ່ກໍານົດ.
ຄວາມຄິດ:ບົດສະຫລຸບນີ້ໄດ້ບັນທຶກໃນສາຍໂຮງເກັບຊື່ "upload".
- ກັບໄປຕໍ່ຫລັງ PHP ການສ້າງ/ຂຽນບັນນາດ
- ກັບໄປຕໍ່ຫລັງ PHP Cookies