PHP, jest łatwy do przesyłania plików na serwer.
Jednak z łatwością przychodzi niebezpieczeństwo, więc zawsze należy zachować ostrożność podczas umożliwiając przesyłanie plików!
Skonfiguruj "php.ini" Plik
Po pierwsze, upewnij się, że PHP jest skonfigurowany tak, aby umożliwić przesyłanie plików.
W swojej "php.ini" pliku, szukaj dyrektywy file_uploads i ustawić go w położeniu On:
file_uploads = On
Tworzenie formularza HTML
Następnie należy utworzyć formularz HTML, który pozwoli użytkownikom wybrać plik obrazu chcą przesłać:
<!DOCTYPE html>
<html>
<body>
<form action="upload.php" method="post"
enctype="multipart/form-data">
Select
image to upload:
<input type="file" name="fileToUpload"
id="fileToUpload">
<input
type="submit" value="Upload Image" name="submit">
</form>
</body>
</html>
Niektóre zasady do naśladowania dla formularza HTML powyżej:
- Upewnij się, że forma wykorzystuje metodę = „post”
- Postać musi także following cechę: enctype = „wieloczęściowy / postać transmisji danych”. Określa on, jaka treść typu użyć podczas składania formularza
Bez powyższych wymagań, przesyłanie plików nie będzie działać.
Inne rzeczy do zawiadomienia:
- type="file" atrybutem <input> znacznik pokazuje pole wprowadzania jako kontrolą plików-select, z "Browse" przycisk obok kontroli wejściowej
Powyższy formularz wysyła dane do pliku o nazwie "upload.php" , które będziemy tworzyć dalej.
Tworzenie upload plików PHP Script
"upload.php" plik zawiera kod do przesyłania pliku:
<?php
$target_dir = "uploads/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType =
pathinfo($target_file,PATHINFO_EXTENSION);
// Check if image file is a
actual image or fake image
if(isset($_POST["submit"])) {
$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check !== false) {
echo
"File is an image - " . $check["mime"] . ".";
$uploadOk = 1;
} else {
echo "File is not an image.";
$uploadOk = 0;
}
}
?>
skrypt PHP, wyjaśnia:
- $ target_dir = "uploads/" - określa katalog, w którym plik ma zostać umieszczony
- $ Target_file określa ścieżkę do pliku, który ma być przesłany
- $ uploadOk = 1 nie jest jeszcze używany (will be used later)
- $ ImageFileType posiada rozszerzenie pliku
- Następnie sprawdź, czy plik obraz jest rzeczywisty obraz lub fałszywy obraz
Uwaga: Musisz utworzyć nowy katalog o nazwie "uploads" w katalogu, w którym "upload.php" rezyduje plik. Przesłane pliki zostaną zapisane tam.
Sprawdź, czy plik już istnieje
Teraz możemy dodać pewne ograniczenia.
Po pierwsze, będziemy sprawdzać, czy plik już istnieje w "uploads" folderu. Jeśli tak, wyświetlany jest komunikat o błędzie, a $ uploadOk jest ustawiony na 0:
// Check if file already exists
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
Rozmiar pliku granica
Pole wejściowe plik HTML w naszym formularzu powyżej nazywa się "fileToUpload" .
Teraz chcemy sprawdzić rozmiar pliku. Jeśli plik jest większy niż 500kb, wyświetlany jest komunikat o błędzie, a $ uploadOk jest ustawiony na 0:
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
echo "Sorry, your file is too large.";
$uploadOk = 0;
}
Rodzaj Limit pliku
Poniższy kod tylko pozwala użytkownikom przesyłać pliki JPG, JPEG, PNG i GIF. Wszystkie inne typy plików daje komunikat o błędzie przed ustawienie $ uploadOk 0:
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType
!= "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
Kompletny File Upload PHP Script
Pełna "upload.php" plik teraz wygląda tak:
<?php
$target_dir = "uploads/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType =
pathinfo($target_file,PATHINFO_EXTENSION);
// Check if image file is a
actual image or fake image
if(isset($_POST["submit"])) {
$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check !== false) {
echo
"File is an image - " . $check["mime"] . ".";
$uploadOk = 1;
} else {
echo "File is not an image.";
$uploadOk = 0;
}
}
// Check if file already
exists
if (file_exists($target_file)) {
echo
"Sorry, file already exists.";
$uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
echo "Sorry, your file is too large.";
$uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType
!= "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if
($uploadOk == 0) {
echo "Sorry, your file was not
uploaded.";
// if everything is ok, try to upload file
} else {
if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been
uploaded.";
} else {
echo "Sorry, there was an error uploading your file.";
}
}
?>
Wypełnij PHP Plików Reference
Aby uzyskać pełną odniesień do funkcji systemu plików, przejdź do naszej pełnej PHP systemu plików Reference .