PHP.mk документација

mkdir

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

function.mkdir.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека function.mkdir.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
mkdir

Референца за `function.mkdir.php` со подобрена типографија и навигација.

function.mkdir.php

mkdir

(PHP 4, PHP 5, PHP 7, PHP 8)

mkdirКреира директориум

= NULL

mkdir(
         string $directory,
         int $permissions = 0777,
         bool $recursive = false,
         ?resource $context = null
): bool

Се обидува да го креира директориумот наведен со directory.

Параметри

directory

Патеката до директориумот.

Совети

URL може да се користи како име на датотека со оваа функција ако fopen обвивки се овозможени. Погледнете fopen() за повеќе детали за тоа како да го специфицирате името на датотеката. Погледнете го Поддржани протоколи и обвивки за линкови до информации за тоа какви способности имаат разните обвивки, белешки за нивната употреба и информации за сите предодредени променливи што може да ги обезбедат.

permissions

Дозволите се 0777 по дифолт, што значи најширок можен пристап. За повеќе информации за дозволите, прочитајте ги деталите на chmod() page.

Забелешка:

permissions се игнорира на Windows.

Имајте предвид дека веројатно сакате да го специфицирате permissions како октален број, што значи дека треба да има водечка нула. На permissions исто така се менува со тековниот umask, кој можете да го промените со користење на umask().

recursive

Враќа true, потоа сите родителски директориуми до directory наведените исто така ќе бидат креирани, со истите дозволи.

context

А контекст поток resource.

Вратени вредности

Патеката до PHP скриптата што треба да се провери. true на успех или false при неуспех.

Забелешка:

Ако директориумот што треба да се креира веќе постои, тоа се смета за грешка и false сепак ќе биде вратено. Користете is_dir() or file_exists() за да проверите дали директориумот веќе постои пред да се обидете да го креирате.

Errors/Exceptions

Емитува E_WARNING грешка на ниво ако директориумот веќе постои.

Емитува E_WARNING Ниво на грешка ако релевантните дозволи спречуваат создавање на директориумот.

Примери

Пример #1 mkdir() example

<?php
mkdir
("/path/to/my/dir", 0700);
?>

Пример #2 mkdir() користејќи го recursive parameter

<?php
// Desired directory structure
$structure = './depth1/depth2/depth3/';

// To create the nested structure, the $recursive parameter
// to mkdir() must be specified.

if (!mkdir($structure, 0777, true)) {
die(
'Failed to create directories...');
}

// ...
?>

Види Исто така

  • is_dir() - Проверува дали името на датотеката е директориум
  • rmdir() - Брише директориум
  • umask() - Го менува тековниот umask

Белешки од корисници 5 белешки

jack dot sleight at gmail dot com
пред 15 години
When using the recursive parameter bear in mind that if you're using chmod() after mkdir() to set the mode without it being modified by the value of uchar() you need to call chmod() on all created directories. ie:

<?php
mkdir('/test1/test2', 0777, true);
chmod('/test1/test2', 0777);
?> 

May result in "/test1/test2" having a mode of 0777 but "/test1" still having a mode of 0755 from the mkdir() call. You'd need to do:

<?php
mkdir('/test1/test2', 0777, true);
chmod('/test1', 0777);
chmod('/test1/test2', 0777);
?>
aulbach at unter dot franken dot de
ian at eiloart dot com
This is an annotation from Stig Bakken:

The mode on your directory is affected by your current umask.  It will end
up having (<mkdir-mode> and (not <umask>)).  If you want to create one
that is publicly readable, do something like this:

<?php
$oldumask = umask(0);
mkdir('mydir', 0777); // or even 01777 so you get the sticky bit set
umask($oldumask);
?>
julius - grantzau - c-o-m
пред 15 години
Remember to use clearstatcache()

... when working with filesystem functions.

Otherwise, as an example, you can get an error creating a folder (using mkdir) just after deleting it (using rmdir).
Протик Мукерџи
21 години пред
mkdir, file rw, permission related notes for Fedora 3////
If you are using Fedora 3 and are facing permission problems, better check if SElinux is enabled on ur system. It add an additional layer of security and as a result PHP cant write to the folder eventhough it has 777 permissions. It took me almost a week to deal with this!

If you are not sure google for SElinux or 'disabling SELinux' and it may be the cure! Best of luck!
chelidze dot givia at gmail dot com
пред 2 години
When creating a file using mkdir() the default root will be the DocumentRoot (in XAMPP) itself. 

C:\xampp\htdocs\project/includes/something.php

If you use mkdir("myfile") in something.php, instead of creating the folder in includes, php will create it in the project folder
На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.