PHP 8.3.4 Released!

ftp_mkdir

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

ftp_mkdirCria um diretório

Descrição

ftp_mkdir(FTP\Connection $ftp, string $directory): string|false

Cria o diretório especificado pelo parâmetro directory no servidor FTP.

Parâmetros

ftp

Uma instância de FTP\Connection.

directory

O nome do diretório que será criado.

Valor Retornado

Retorna o nome do diretório recém criado em caso de sucesso ou false em caso de erro.

Erros/Exceções

Emite um erro de nível E_WARNING se o diretório já existir ou se as permissões relevantes impedem a criação do diretório.

Registro de Alterações

Versão Descrição
8.1.0 O parâmetro ftp agora espera uma instância de FTP\Connection; anteriormente, um resource era esperado.

Exemplos

Exemplo #1 Exemplo de ftp_mkdir()

<?php

$dir
= 'www';

// define uma conexão básica
$ftp = ftp_connect($ftp_server);

// login com usuário e senha
$login_result = ftp_login($ftp, $ftp_user_name, $ftp_user_pass);

// tenta criar o diretório $dir
if (ftp_mkdir($ftp, $dir)) {
echo
"Sucesso na criação de $dir\n";
} else {
echo
"Houve um problema ao tentar criar $dir\n";
}

// fecha a conexão
ftp_close($ftp);
?>

Veja Também

add a note

User Contributed Notes 5 notes

up
48
PINAR Musa
10 years ago
Here's the correct code for making recursive directories:

<?php

// function
function ftp_mksubdirs($ftpcon,$ftpbasedir,$ftpath){
@
ftp_chdir($ftpcon, $ftpbasedir); // /var/www/uploads
$parts = explode('/',$ftpath); // 2013/06/11/username
foreach($parts as $part){
if(!@
ftp_chdir($ftpcon, $part)){
ftp_mkdir($ftpcon, $part);
ftp_chdir($ftpcon, $part);
//ftp_chmod($ftpcon, 0777, $part);
}
}
}

// usage
$path_of_storage = '/var/www/uploads';
$newftpdir = '2013/06/11/username';

$conn_id = ftp_connect($ftpserver);
ftp_login($conn_id, $login, $pass);
ftp_mksubdirs($conn_id,$path_of_storage,$newftpdir);
ftp_close($conn_id);

?>
up
1
vladimir at lukianov dot name
20 years ago
For recurrent following function work better.
Some ftp servers (like WarFTP) become demented if you'll
try mkdir not from root dir and if path will be relative.
The second if one of dir (like '/') already exist You'll get access denied.

<?php
function MkDir($path)
{
$dir=split("/", $path);
$path="";
$ret = true;

for (
$i=0;$i<count($dir);$i++)
{
$path.="/".$dir[$i];
echo
"$path\n";
if(!@
ftp_chdir($this->conn_id,$path)){
@
ftp_chdir($this->conn_id,"/");
if(!@
ftp_mkdir($this->conn_id,$path)){
$ret=false;
break;
}
}
}
return
$ret;
}
?>
up
0
butch AT 4RealMedia dot com
17 years ago
When trying to user the ftp_mkdir, or ftp_chdir I've noticed that some servers like the entire path such as

/usr/local/home/username/sitename/directory/

and other servers, want you to use the path from the initial login, such as just /sitename/directory/

Just wanted to pass this on
up
-1
postmaster at 250union dot community
5 years ago
if(!@ftp_chdir($ftpcon, $part)){
ftp_mkdir($ftpcon, $part);
ftp_chdir($ftpcon, $part);
//ftp_chmod($ftpcon, 0777, $part);
}

This if part of answer below, if you want working chmod you need to replace it with:

if(!@ftp_chdir($ftpcon, $part)){
ftp_mkdir($ftpcon, $part);
ftp_chmod($ftpcon, 0777, $part);
ftp_chdir($ftpcon, $part);
}
up
-6
4alexr at gmail dot com
6 years ago
Updated and correct code for making recursive directories:

/**
* A function to create ftp directories recursively.
*
* @param $ftpcon the ftp connection resource
* @param $baseDir
* @param $path
* @param int $mode
* @return bool
*/
function ftp_mksubdirs($ftpcon, $baseDir, $path, $mode = 0775) {
$path = dirname($path);

if ($baseDir !== DIRECTORY_SEPARATOR && strpos($path, $baseDir) !== false) {
if (empty($path)) {
// $baseDir equals to $path, it can only mean that this folder already exists
return false;
}

if ($path[0] == DIRECTORY_SEPARATOR) {
$path = substr($path, 1);
}
} else {
if ($path[0] == DIRECTORY_SEPARATOR) {
$path = substr($path, 1);
}
}

@ftp_chdir($ftpcon, $baseDir);
$parts = explode(DIRECTORY_SEPARATOR, $path);
$created = [];
foreach ($parts as $part) {
if (!@ftp_chdir($ftpcon, $part)) {
$createdDir = @ftp_mkdir($ftpcon, $part);

if ($createdDir !== false) {
ftp_chmod($ftpcon, $mode, $createdDir);
}

$created[] = $createdDir;
@ftp_chdir($ftpcon, $part);
}
}

return !in_array(false, $created);
}
To Top