linux系统vsftpd,linux中的vsftpd安装及配置

本文详细介绍了在CentOS 6环境下VSFTPD的安装与配置过程,包括如何配置匿名用户和本地用户登录、设置默认进入的公共目录、调整文件上传权限、配置chroot限制用户访问范围以及更改监听端口等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

运行环境:centos6 Vmware

一、安装vsftpdyum -y install vsftpd

9f040d3684a3ed05054191c0881a130c.pngyum -y install xinetd

896808751cd872181a7507ffc92257a9.png

二、配置vsftpd

1、是否开始匿名用户

启动服务之后我们通过lftp命令连接服务器lftp 172.18.251.126 (服务器的ip)

62cf741bf4be08c946ba56fd2395060d.png

登陆成功之后我们可以直接读取pub目录下的文件,无需登陆用户

618a3ac609139dfc1820fa2c60c31bc5.png

我们可以通过编辑vsftpd服务端的配置文件来实现vim /etc/vsftpd/vsftpd.conf

8c5110af2a67a7da8362a31bdd097fdb.png

找到这一行配置,将其改为NO,重新启动服务,匿名用户将无法登陆

ebe1b43d0f337fbbbc57011ea9b09ee3.png

5713244f334986ddc8e67ac28403b816.png

在服务器端创建一个用户来进行测试

6e219ec68ec57028fcc0353742f30e1e.png

be0ba454c3e061d5d0d15709cb2c7821.png

SO,问题来了,如何让用户不进入自己的家目录,而是直接进入公共目录

2、用户登陆时默认进入公共目录

通过修改服务器中的配置文件(注意:每一次更改服务配置文件后都要重新启动服务才会生效)vim /etc/vsftpd/vsftpd.conf

添加以下纪录local_enable=YES

local_root=/var/ftp/pub

4721c2a46ff0b97ee2e27004d5bd2f2f.png

用户登陆测试

908cff12f600d920b6134ef5f60bf5dd.png

3、匿名用户和本地用户上传文件及文件的默认权限

客户端登陆ftp服务器,以匿名用户的方式上传文件(需要先开启匿名用户登陆允许,因为上面我们把匿名用户登陆功能关闭了)

在服务器配置文件中修改或添加anonymous_enable=YES

anon_upload_enable=YES(默认为no:关闭)

anon_mkdir_write_enable=YES (匿名用户是否能够创建目录)

b4224a3cb27eaeae25dba66e94fc680f.png

在下面截图中我们可以看到匿名用户仍然不能上传文件,匿名用户上传文件还需要让ftp用户对/var/ftp/pub目录有wx权限(匿名用户默认登陆的时ftp用户,下面截图注释会有提到)

cfeb02f865bd0eddaecffad0bf69b454.png

我们通过设置setfacl只赋予ftp用户wx权限setfacl -m u:ftp:wx /var/ftp/pub

cae94ca209a847a4b2c6dcf084b82fc8.png

客户端登陆测试,成功上传

cc2192a9e8e37593d73284f7475f150e.png

服务器查看,该文件权限为600,可以通过服务器配置文件设置上传文件默认权限

6e578211fdd4d3132be5709edf70a56d.png

在配置文件中添加anon_umask 055

a68aceb1ce7fec081ca5052ed423a514.png

服务器查看该文件权限(因为没有给用户删除权限,所以默认没有给x权限)

d688053fc68d672f16d7312025f28e62.png

客户端上传文件进行测试

b966aef1fdc80559adc8058de186c1a1.png

本地用户上传文件

客户端测试本地用户不能上传文件

389380afd166522f8916de5931092dea.png

服务器端修改配置文件

在服务器配置文件添加(重启服务)write_enable=YES

9d5a6b4cedb352f547dbc4af5d374cd1.png

三、配置vsftpd中的chroot

在vsftpd服务器的默认设置中,本地用户可以切换到主目录以外的目录进行浏览访问,这样对于服务器来说是不×××全的,因为任何用户可以随时浏览到别的用户的私有信息,下面介绍如何使用chroot选项来防止这种情况的发生。

与该功能相关的选项主要包括:chroot_local_user

chroot_list_enable

chroot_list_file

可以通过如下两种方法来设置chroot,从而杜绝上述不安全的情况发生:

(1)设置所有的本地用户执行chroot,只要将/etc/vsftpd/vsftpd.conf文件中的chroot_local_ user值置为YES,即chroot_local_user=YES

f7750dfb8e0258be61ef12e75d788f44.png

(2)设置指定的用户执行chroot,按照如下方法进行设置:chroot_local_user=NO

chroot_list_enable=YES

chroot_list_file=/etc/vsftpd.chroot_list

设置后,只有/etc/vsftpd.chroot_list文件中指定的用户才能够执行chroot命令。

229909a710b86f9349b87d8f70ef19f7.png

未设置chroot之前的效果

2747143b7c7c99f25f235e630e2b4cee.png

设置chroot之后的效果

429280b6d892aa528318df8901d311a0.png

在使用FTP服务的过程中,可以使该服务在非标准端口(非21端口)工作,不过要完成这项工作,须要使vsftpd服务器运行在独立启动方式下,而且要配置vsftpd的主配置文件/etc/vsftpd/vsftpd.conf,将listen_port=10003或者是其他端口号的选项加入该文件即可,然后要重新启动vsftpd守护进程:service vsftpd restart

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值