vsftpd实现匿名用户只能上传不能下载

声明

作者:昨夜星辰

博客:http://yestreenstars.blog.51cto.com/

本文由本人创作,如需转载,请注明出处,谢谢合作!

目的

搭建一台FTP服务器,供学生上传作业使用。

要求

1.学生可以直接访问FTP服务器,无需登录;

2.只能上传文件,不能创建文件夹、重命名、删除等;

3.不能下载文件(防抄袭);

4.不能在线查看文件。

配置

# 创建upload目录
mkdir /var/ftp/upload
# 改变属主
chown ftp /var/ftp/upload

# 用以下内容替换/etc/vsftpd/vsftpd.conf文件原来的内容
listen=YES
write_enable=YES
anon_upload_enable=YES

# 重启vsftpd服务
service vsftpd restart

原理解释

第一个要求是通过anonymous_enable=YES参数实现的,即允许匿名用户登录,因为这个参数的值默认就是YES,所以可以不写入配置文件。

第二个要求是通过anon_upload_enable=YESanon_mkdir_write_enable=NOanon_other_write_enable=NO这三个参数实现,即允许匿名用户上传,不允许匿名用户创建目录和其他写入权限(删除和重命名),因为anon_mkdir_write_enableanon_other_write_enable这两个参数默认值都是NO,所以也可以不写入配置文件。

第三个要求是通过anon_world_readable_only=YESanon_umask=077这两个参数实现的,具体原理可以参见我的另外一篇博客:anon_world_readable_only的作用。

第四个要求是针对txt文档而言,如果学生上传的作业不是以txt文档保存的话就不需要配置了,当然,你可以利用file_open_mode=0000来控制上传文件的权限,这样就算是txt文件,也无法在线查看了。

你可能感兴趣的:(vsftpd,匿名用户,不能下载,只能上传)