vsfptdをインストールし、それを使用してユーザーを作成しました。
sudo useradd sftp -d /var/www/magento2
その後、vsftpd用に次の設定を作成しました。
listen=NO
listen_ipv6=YES
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
local_root=/var/www/magento2
chroot_local_user=YES
secure_chroot_dir=/var/run/vsftpd/empty
pam_service_name=vsftpd
force_dot_files=YES
pasv_min_port=40000
pasv_max_port=50000
allow_writeable_chroot=YES
userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
log_ftp_protocol=YES
pasv_enable=NO
# SSL
ssl_enable=YES
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
allow_anon_ssl=NO
force_local_data_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
require_ssl_reuse=NO
ssl_ciphers=HIGH
この設定を使用して Filezilla を使用して接続すると、代わりに/
ディレクトリに移動しますが、/var/www/magento2
この行をコメントアウトすると任意chroot_local_user=YES
のフォルダに移動できます。
この問題を解決するにはどうすればよいですか?ユーザーはそのフォルダにのみアクセスできる必要があり、/var/www/magento2
他のフォルダにはアクセスできません。