我正在尝试使用 FTP 编写远程文件。我正在使用flysystem 库在 PHP 中执行此操作。它似乎运作良好。但是,当我尝试写入特定位置的文件时,它会给我 chdir() 错误。为了测试这个,我在 FTP 控制台上尝试了这个。
[kbg@ip-192-0-1-118 ~]$ ftp
ftp> open 192.0.1.118
Connected to 192.0.1.118 (192.0.1.118).
220 (vsFTPd 2.2.2)
Name (192.0.1.118:kbg):
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> pwd
257 "/"
ftp> cd /projects/test
550 Failed to change directory.
Run Code Online (Sandbox Code Playgroud)
当我在 vsftpd.conf 文件中更改以下内容时,它似乎运行良好。
chroot_local_user=NO
chroot_list_enable=NO
Run Code Online (Sandbox Code Playgroud)
我什至可以使用 PHP 库进行编写,没有任何问题。允许我的用户写入 /projects/test/t1.conf 文件中的文件的正确方法是什么?
您有,chroot_local_user = No
但您似乎无权遍历 /projects/test 。您必须允许 ftp_user 遍历上面的目录。要做到这一点 :-
setfacl -R -m u:ftp_user:rwx /projects/test
Run Code Online (Sandbox Code Playgroud)
但是,如果您必须更改目录内容,则必须更好地添加 ftp_user 以通过以下方式说 ftp 组:-
usermod -a -G ftp ftp_user
Run Code Online (Sandbox Code Playgroud)
如果你还没有,你必须添加 ftp 组。
现在通过以下方式更改目录的组权限和所有权:-
chown -R :ftp /projects/test
chmod -R g+rwx /projects/test
Run Code Online (Sandbox Code Playgroud)
并设置 guid 位,以便它里面的所有未来文件和目录都允许 ftp_user 访问它们。
chmod g+s /projects/test
Run Code Online (Sandbox Code Playgroud)
而不是 group ,可以遵循相同的程序来获取用户所有权、权限和位,但我假设如果您正在使用 web 目录,所有权将默认为服务器用户,如 www、www-data、apache 等,因此您必须更好地与这里的团体合作。
或者安全选项: -
chroot_local_user = Yes您可以将目录绑定到 ftp 用户的主目录下。要做到这一点 :-
mount --bind /projects/test /home/ftp_user/projects_test
Run Code Online (Sandbox Code Playgroud)
要使其持久化,请将条目添加到 fstab 中:-
/projects/test /home/ftp_user/projects_test none bind 0 0
Run Code Online (Sandbox Code Playgroud)
现在你可以像 /projects/test 一样遍历 projects_test。