mysql — PHP mkdir (): в доступе отказано

У меня есть простое приложение PHP / HTML / CSS, которое создает папку для новых зарегистрированных пользователей. Он отлично работал на моем тестовом сайте, и я не готов начать работу, но я получаю сообщение об ошибке «mkdir (): Permission denied». Насколько я знаю, все настройки одинаковы на обоих сайтах, а разрешение файла для корневой папки и папки загрузки установлено на 755. Все остальное работает как положено, примите код ниже …

if (count($errors) == 0) {
$pword = md5($pword_1);//encrypt the pword before saving in the database
$rand = "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyz";
$rand = str_shuffle($rand);
$folder = substr($rand, 0, 10);
$regDate = date("Y-m-d");
$token = 0;
$tokenExp = 0;
$curDir = getcwd();

if(mkdir($curDir . "/uploads/" . $folder, 0755)){
$query = "INSERT INTO users (uname, email, pword, folder, regDate, token, tokenExp) VALUES ('$uname', '$email', '$pword', '$folder', '$regDate', '$token', '$tokenExp')";
mysqli_query($db, $query);
$_SESSION['uname'] = $uname;
$_SESSION['success'] = "You are now logged in";
header('location: index.php');
}else{
array_push($errors, "An error occurred creating your account!!!");
}
}

Насколько я могу судить, что я не могу создать папку пользователя, я не могу загружать файлы. Однако при устранении неполадок, когда я вручную добавляю папку на сервер, я все равно получаю ошибку «путь не найден». Вот код загрузки файла …

if(isset($_POST['uploads'])){
$uname = mysqli_real_escape_string($db, $_POST['uname']);
$name = $_FILES['file']['name'];
$size = $_FILES['file']['size'];
$type = $_FILES['file']['type'];
$tmp_name = $_FILES['file']['tmp_name'];
$extension = substr($name, strpos($name, '.') + 1);
$max_size = 2500000; //bytes

if(empty($name)) {
echo "<p class='error'>Please Select a File</p>";
}else{
if($extension == "jpg" || $extension == "jpeg" || $extension == "gif" || $extension == "tif" || $extension == "png" || $extension == "pdf"){
if($extension == $size<=$max_size){
$getFold = "SELECT * FROM users WHERE uname='$uname'";
$getFold = mysqli_query($db, $getFold);
while($for = mysqli_fetch_assoc($getFold)){
$folder = $for['folder'];
}
$location = "uploads/" . $folder . "/";
if(move_uploaded_file($tmp_name, $location . $name)){
$query = "INSERT INTO `upload` (name, size, type, location, uname, folder) VALUES ('$name', '$size', '$type', '$location', '$uname', '$folder')";
$result = mysqli_query($db, $query);
if($result){
echo "<p class='success'>File has been uploaded successfully!!!</p>";
}else{
echo "<p class='error'>Failed to upload file information to database!!! Filename already exist!</p>";
}
}else{
echo "<p class='error'>Failed to Upload File</p>";
}
}else{
echo "<p class='error'>File size should be 3MB or less</p>";
}
}else{
echo "<p class='error'>The selected file is not a JPG, JPEG, GIF, TIF, PNG, or PDF file type!!!</p>";
}
}
}

0

Решение

Вы создаете каталог с разрешениями 0755, что означает полный доступ для владельца и только чтение + выполнение для остальных. Измените это на 0777 или же 0766; полный доступ к любому или полный доступ к владельцу и чтение + запись для всех.
Это также относится к родительской папке.

0

Другие решения

Вам нужно изменить владельца папки, в которой вы пытаетесь создать подпапки для своих пользователей:

  1. apache — в случае с сервером CentOS
  2. www-data — в случае сервера Ubuntu

Вы можете сделать это с помощью следующей команды

sudo chown -R www-data /folder

-R Флаг означает, что он рекурсивный, поэтому процесс apache / httpd, который запускает php, будет владеть всеми вложенными папками, которые вы, возможно, также создали.

Для получения дополнительной информации об этой команде посмотрите на это ТАК сообщение

0

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector