Главная страница статей --> Советы по фотошопу, графике и хитрости в построении php кода

Работа с FTP средствами PHP

Источник: realcoding.net

Протокол FTP (File Transfer Protocol - протокол передачи файлов) - один из старейших протоколов Интернета, предназначенный для передачи файлов между двумя хостами.

Как правило, при работе с FTP выполняются следующие стандартные действия:

соединение с удаленным FTP-сервером
регистрация на FTP-сервере
загрузка файлов с сервера или на сервер
закрытие соединения
Соединение с FTP-сервером
Соединение с удаленным FTP-сервером выполняется с помощью функции ftp_connect:

Синтаксис:

ftp_connect (string host [, int port [, int timeout]])

В качестве обязательного параметра эта функция принимает имя хоста host, с которым необходимо установить соединение. Второй необязательный параметр port указывает на номер порта, через который осуществляется соединение. Если этот параметр не указан, то соединение осуществляется через порт 21, являющийся стандартным FTP-портом. Третий необязательный параметр определяет максимально время выполнения сценария (тайм-аут) и по умолчанию равен 90 секундам.

Соединение с удаленным FTP-сервером

<?
 $host = "ftp://ftp.server.ru";
 $connect = ftp_connect($host);
 if(!$connect)
 {
 echo("Ошибка соединения");
 exit;
 }
 else
 {
 echo("Соединение установлено");
 }
?>

Регистрация на FTP-сервере
После того, как соединение установлено, необходимо зарегистрироваться на сервере с определенным именем и паролем. Сделать это можно при помощи функции ftp_login.

<?
 $user = "maks";
 $password = "password";
 $result = ftp_login($connect, $user, $password);
?>

Как видно из листинга, функция ftp_login принимает три параметра: дескриптор FTP-соединения, возвращаемый функцией ftp_connect, имя пользователя и пароль.

Замечание: Регистрация на сервере не требуется, если FTP-сервер является анонимным.

Закрытие соединения
По окончании сеанса связи с FTP-сервером, нужно закрыть FTP-соединение с помощью функции ftp_quit, принимающей в качестве единственного параметра дескриптор FTP-соединения:

Синтаксис:

ftp_quit($connect);

Загрузка файлов с сервера
Загрузка файлов с сервера осуществляется при помощи функции ftp_get:

Синтаксис:

bool ftp_get(int ftp_connect, string local_file,  string remote_file, int mode);

Аргумент mode, задающий режим пересылки файлов, должен быть указан как константа FTP_BINARY или FTP_ASCII. Режим FTP_ASCII используется для пересылки файлов, состоящих только из ASCII-символов (т. е. текстовых файлов), а двоичный режим - для пересылки всех остальных файлов.

К примеру:

<?
 $local_file = "/users/local.txt";
 $remote_file = "remote.txt";
 ftp_get($connect, $local_file, $remote_file, FTP_BINARY);
?>

Переход в родительский каталог
Изменение текущего рабочего каталога на родительский производится с помощью функции ftp_cdup:

Синтаксис:

bool ftp_cdup(int ftp_connect);

Пример:

<?
 $host = "ftp.server.ru";
 $port = 21;
 $user = "anonymous";
 $passwrod = "password";
 $connect = ftp_connect($host, $port, 150);
 if(!$connect)
 {
 exit();
 }
 $result = ftp_login($connect, $user, $password);
 if($result)
 {
 // сохраняем имя текущего рабочего каталога
 $current_dir = ftp_pwd($connect);
 // переходим в родительский каталог
 ftp_cdup($connect);
 // сохраняем имя нового каталога
 $new_dir = ftp_pwd($connect);
 }
 else
 {
 ftp_quit($connect);
 exit();
 }
 // Закрываем соединение
 ftp_quit($connect);
?>

Изменение текущего рабочего каталога
Изменение текущего рабочего каталога на указанный осуществляется при помощи функции ftp_chdir:

<?
 $new_dir = "web";
 ftp_chdir($connect, $new_dir);
?>

Как видно из этого листинга, функция ftp_chdir имеет два параметра: дескриптор соединения $connect и имя нового каталога $new_dir.

Удаление файлов
Удалить файл с FTP-сервера можно с помощью функции ftp_delete:

Синтаксис:

bool ftp_delete(int ftp_connect, string remote_file);

Здесь ftp_connect - дескриптор соединения, а remote_file - имя удаляемого файла.

Создание каталога
Новый каталог можно создать, используя функцию ftp_mkdir:

Синтаксис:

string ftp_mkdir(int ftp_connect, string directory);

Эта функция возвращает имя созданного каталога или false в случае неудачи:

<?
 $dir = "web";
 $created_dir = ftp_mkdir($connect, $dir);
?>

Перечисление файлов в каталоге
Узнать, какие файлы находятся в текущем каталоге, можно применив функцию ftp_nlist:

Синтаксис:

array ftp_nlist(int ftp_connect, string directory);

Пример:

<?
 $file_list = ftp_nlist($connect, ".");
 if(is_array($file_list))
 {
 foreach($file_list as $file)
 {
 echo("$file <br>");
 }
 }
?>

Переименование файлов
Переименовать файлы на FTP-сервере осуществляется с помощью функции ftp_rename:

Синтаксис:

bool ftp_rename(int ftp_connect, string from, string to);

Удаление каталогов
Для удаления каталогов применяется функция ftp_rmdir:

Синтаксис:

bool ftp_rmdir(int ftp_connect, string directory);

Определение размера файлов
Для определения размера файлов существует функция ftp_size:

Синтаксис:

int ftp_size(int ftp_connect, string filepath);

В случае неудачи функция возвращает -1. К примеру:

<?
 $file = "/web/user/file.txt";
 $file_size = ftp_size($connect, $file);
 if ($file_size == -1)
 {
 echo("Размер файла не определен");
 }
 else
 {
 echo("Файл $file имеет размер $file_size байт");
 }
?>

Посылка команды на сервер
Послать на сервер команду можно с помощью функции ftp_site:

Синтаксис:

bool ftp_site(int ftp_connect string command);

Эта функция посылает на сервер команду SITE. Как правило, с помощью команд SITE выполняются такие команды операционной системы, как chmod. Список команд SITE, поддерживаемый сервером можно узнать, подключившись к нему и выполнив команду REMOTEHELP. Ниже приведен код, позволяющий изменить права доступа к файлу на удаленном сервере:

<?
 $command = "chmod 0766 /web/user/file.txt";
 ftp_site($connect, $command);
?>

Работа через брандмауэр
При работе с FTP-сервером через брандмауэр часто бывает необходимо изменить активный режим, при котором соединение инициируется сервером, на пассивный, при котором соединение инициируется клиентом. Это можно сделать, применив функцию ftp_pasv:

<?
 $pasv_flag = true;
 $pasv_result = $pasv_flag ? "enabled" : "disabled";
 ftp_pasv($connect, $pasv_flag);
?>



Похожие статьи:
- Первоначальная настройка MySQL
- Краткий обзор некоторых возможностей MySQL. Советы по оптимизации.
- Поиск - простой и видимый
- Правила написания сообщений об ошибках
- PHP gzip module
- Применение cURL и libcurl в php
- Регулярные выражения, Часть I
- Perl и работа с сокетами
- Безопасно-ориентированное программирование в PHP5
- Создание индекса для сайта
- Счетчик посещений на Perl
- Python: Питон высокого полета...
- Семь изысканных рецептов для программистов


Оглавление | Обсудить на форуме | Главная страница сайта | Карта сайта |

Контакты
Редакция:
[0.002]