Я создаю загрузчик нескольких файлов, используя учебник на этом сайте, http://techstream.org/Web-Development/PHP/Multiple-File-Upload-with-PHP-and-MySQL. И это прекрасно работает, однако я хотел бы сохранить изображение как URL в SQL, а не только их имена, и использовать имя изображения в качестве заголовка. Вот код, который я сейчас использую:
if (isset($_POST['add_photos'])) {
include 'connect.php';
$album = (isset($_POST['album']) ? $_POST['album'] : null);
$errors= array();
foreach($_FILES['photos']['tmp_name'] as $key => $tmp_name ){
$file_name = $key.$_FILES['photos']['name'][$key];
$file_size =$_FILES['photos']['size'][$key];
$file_tmp =$_FILES['photos']['tmp_name'][$key];
$file_type=$_FILES['photos']['type'][$key];
if($file_size > 2097152){
$errors[]='File size must be less than 2 MB';
}
include 'connect.php';
$stmt = $conn->prepare("INSERT into album_images(imageURL, AlbumID) VALUES (?, ?)");
$stmt->bind_param('ss', $file_name,$album);
$desired_dir="media/albums";
if(empty($errors)==true){
if(is_dir($desired_dir)==false){
mkdir("$desired_dir", 0700); // Create directory if it does not exist
}
if(is_dir("$desired_dir/".$file_name)==false){
move_uploaded_file($file_tmp,"user_data/".$file_name);
}else{ //rename the file if another one exist
$new_dir="media/albums/".$file_name.time();
rename($file_tmp,$new_dir) ;
}
$stmt->execute();
$stmt->close();
}else{
print_r($errors);
}
}
if(empty($error)){
echo "Success";
}
}
HTML код
<form id="add-photos" action="" method="post" enctype="multipart/form-data">
<h5>Add Photos</h5>
<div class="input-short" id="select_album">
<?php select_album("SELECT * FROM album"); ?>
</div>
<label class="myLabel" id="upload-images">
<input type="file" name="photos[]" id="fileToUpload" multiple="multiple"/>
<span>Select Photos</span>
</label>
<button id="facebook-image-submit" type="submit" name="add_photos">Add Photos</button>
</form>
Этот код дает мне следующие ошибки:
Предупреждение: mkdir (): нет такого файла или каталога в C: \ xampp \ htdocs \ WebDevelopment \ AfterGlowWebsite \ CMS \ functions.php в строке: mkdir («$ required_dir», 0700); // Создать каталог, если он не существует #
Файлы добавляются в SQL, но не загружаются в каталог.
Вопрос был решен. Вот решение:
/* upload photos to gallery */
if (isset($_POST['add_photos'])) {
include 'connect.php';
$album = (isset($_POST['album']) ? $_POST['album'] : null);
$errors= array();
foreach($_FILES['photos']['tmp_name'] as $key => $tmp_name ){
$file_name = $key.$_FILES['photos']['name'][$key];
$file_size =$_FILES['photos']['size'][$key];
$file_tmp =$_FILES['photos']['tmp_name'][$key];
$file_type=$_FILES['photos']['type'][$key];
if($file_size > 2097152){
$errors[]='File size must be less than 2 MB';
}
include 'connect.php';
$imageURL = "media/albums/".$file_name;
$stmt = $conn->prepare("INSERT into album_images(imageURL, AlbumID) VALUES (?, ?)");
$stmt->bind_param('ss', $imageURL ,$album);
$desired_dir="../media/albums";
if(empty($errors)==true){
if(is_dir($desired_dir)==false){
mkdir($desired_dir, 0700); // Create directory if it does not exist
}
if(is_dir($desired_dir."/".$file_name)==false){
move_uploaded_file($file_tmp,"../media/albums/".$file_name);
}else{ //rename the file if another one exist
$new_dir="media/albums/".$file_name.time();
rename($file_tmp,$new_dir) ;
}
$stmt->execute();
$stmt->close();
}else{
print_r($errors);
}
}
if(empty($error)){
echo "Success";
}
Проблема заключалась в том, что я написал user_data, а не media / albums в файле move_uploaded_file ($ file_tmp, «../ media / album /».$ file_name);
}
Других решений пока нет …