uz
DF
Daniil Fedorov
июля 8, 2025
Обновлено июля 8, 2025

FTPS

FTPS (FTP Secure) — это усовершенствованный вариант стандартного протокола FTP (File Transfer Protocol), дополненный механизмом шифрования посредством SSL/TLS. Он предназначен для безопасного обмена файлами через сеть, минимизируя риск перехвата данных и атак «человек посередине» (MITM).

Принцип работы FTPS

Узнайте, как FTPS (FTP Secure) защищает передачу файлов с помощью SSL/TLS, какие у него преимущества и недостатки, а также как настроить FTPS-сервер для безопасного обмена данными.

Существует два режима работы:

  1. Explicit FTPS (явный режим) — клиент инициирует защищённое соединение по запросу перед началом аутентификации. Используется порт 21 для установления соединения и отдельные защищённые порты для передачи файлов.
  2. Implicit FTPS (неявный режим) — шифрование активируется автоматически при подключении. В этом случае используется порт 990 для установления соединения и динамические порты для передачи данных.

Преимущества FTPS

  • Безопасность передачи данных — SSL/TLS защищает информацию от несанкционированного доступа.
  • Поддержка аутентификации через сертификаты — возможно использование клиентских и серверных сертификатов для дополнительной безопасности.
  • Совместимость с FTP-клиентами — поддерживается популярными клиентами, такими как FileZilla, WinSCP.
  • Гибкость в настройке — возможность работы в явном и неявном режимах.

Недостатки FTPS

  • Сложность настройки — требует генерации и конфигурирования сертификатов SSL/TLS, а также открытия множества портов.
  • Проблемы с NAT и фаерволами — использование динамических портов может затруднять передачу данных.
  • Ограниченная поддержка старыми системами — не все старые клиенты и серверы поддерживают FTPS.

Развёртывание FTPS-сервера

1. Установка vsftpd с поддержкой FTPS (Ubuntu/Debian):

sudo apt update
sudo apt install vsftpd openssl

2. Генерация SSL-сертификата:

openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/ssl/private/vsftpd.pem -out /etc/ssl/private/vsftpd.pem

3. Настройка vsftpd для работы с FTPS:

Редактируем файл /etc/vsftpd.conf:

ssl_enable=YES
force_local_logins_ssl=YES
force_local_data_ssl=YES
rsa_cert_file=/etc/ssl/private/vsftpd.pem
pasv_min_port=40000
pasv_max_port=50000

4. Перезапуск службы:

sudo systemctl restart vsftpd

Использование FTPS-клиентов

Популярные программы для работы с FTPS:

  • FileZilla — удобный FTP-клиент с поддержкой FTPS/FTPES.
  • WinSCP — клиент для Windows, поддерживающий SFTP и FTPS.
  • lftp — консольный FTP-клиент для UNIX/Linux.

Итоги

FTPS является эффективным и надёжным способом передачи файлов с шифрованием SSL/TLS. Он востребован в корпоративной среде и при обмене конфиденциальными данными. Однако, если требуется альтернатива с более простой настройкой, можно рассмотреть SFTP (SSH File Transfer Protocol), работающий через защищённый канал SSH.