ftp服务

配置匿名用户ftp

服务基础环境准备,关闭防火墙和selinux

主机名操作系统ip地址
@localhostrhel 7192.168.168.105
@clientrhel 7192.168.168.34

服务端

[root@localhost~]# cat /etc/redhat-release   
Red Hat Enterprise Linux Server release 7.4 (Maipo)
[root@localhostr~]# systemctl stop firewalld.service    
[root@localhost ~]# setenforce 0           #关闭selinux
[root@localhost ~]# hostnamectl set-hostname ftp-client
[root@localhost ~]# bash

客户端

[root@client ~]# systemctl stop firewalld
[root@client ~]# setenforce 0
setenforce: SELinux is disabled

#服务端进行操作
安装vsftpd

[root@localhost~ ~]# yum -y install vsftpd

#启动ftp服务并加入开机自启


[root@localhost ~]# systemctl enable vsftpd

[root@localhost ~]# systemctl start vsftpd

#修改vsftpd主配置文件

[root@localhost~]# vim /etc/vsftpd/vsftpd.conf
#启动匿名用户、允许上传和创建文件权限
anonymous_enable=YES
anon_upload_enable=YES
anon_mkdir_write_enable=YES

修改默认ftp共享⽬目录站点权限,最后重新加载vsftpd服务

[root@localhost~]# chmod -R 777 /var/ftp/
[root@localhost~]# systemctl restart vsftpd

Linux下使⽤用lftp客户端⼯工具访问vsftpd服务验证,安装此⼯工具

[root@localhost~]# yum install lftp -y

使⽤用匿匿名⽤用户登录vsftpd

[root@client ~]# lftp 192.168.168.105
lftp 192.168.168.105:~> ls
ls: 登录失败: 500 OOPS: vsftpd: refusing to run with writable root inside chroot()

遇见问题:登录失败!创建文件失败!上传文件失败!删除文件失败!的解决方法
原因及解决方法

#当我们限定了用户不能跳出其主目录之后,使用该用户登录FTP时往往会遇到这个错误:

500 OOPS: vsftpd: refusing to run with writable root inside chroot ()

这是由于下面的更新造成的:

Add stronger checks for the configuration error of running with a writeable root directory inside a chroot(). This may bite people who carelessly turned on chroot_local_user but such is life.

从2.3.5之后,vsftpd增强了安全检查,如果用户被限定在了其主目录下,则该用户的主目录不能再具有写权限了!如果检查发现还有写权限,就会报该错误。
要修复这个错误,可以用命令chmod a-w /var/ftp/去除用户主目录的写权限

[root@localhost~]# chmod a-w /var/ftp/
[root@localhost~]# systemctl restart vsftpd

再次检测

[root@client ~]# lftp 192.168.168.105
lftp 192.168.168.105:~> ls
drwxrwxrwx    2 0        0               6 Aug 03  2017 pub

#可以看到服务端/var/ftp里面的内容了

新建文件夹试试

lftp 192.168.168.105:/> mkdir lala
mkdir: Access failed: 550 Create directory operation failed. (lala)

#可以看到无法新建lala这个目录,是不是由于权限不够,我们试着给文件写的权限

[root@localhost~ ~]# chmod o+w /var/ftp

#再次新建lala

lftp 192.168.168.105:/> mkdir lala

mkdir 成功, 建立 `lala'
#成功

lftp 192.168.168.105:/> lcd /etc
lcd 成功, 本地目录=/etc
传文件能不能成功
lftp 192.168.168.105:/> put inittab 
put: Access failed: 553 Could not create file. (inittab)

#不能上传文件,可能是selinux的问题

[root@localhost~ ~]# getsebool -a |grep ftp
ftpd_anon_write --> off
ftpd_connect_all_unreserved --> off
ftpd_connect_db --> off
ftpd_full_access --> off
ftpd_use_cifs --> off
ftpd_use_fusefs --> off
ftpd_use_nfs --> off
ftpd_use_passive_mode --> off
httpd_can_connect_ftp --> off
httpd_enable_ftp_server --> off
tftp_anon_write --> off
tftp_home_dir --> off

#可以看到,允许匿名用户上传的给关闭的了。

#现在我们设置布尔值

[root@localhost ~]# setsebool -P allow_ftpd_anon_write=1
[root@localhost ~]# getsebool -a |grep allow_ftpd_anon
[root@localhost ~]# getsebool -a |grep ftp
ftpd_anon_write --> on

##OK,允许匿名用户的上传就给打开了。
#但是还有一点,/var/ftp/pub的context值是不正确的,
#现在我们必须调整这个/var/ftp/pub目录的context值。

[root@localhost ~]# ls -ldZ /var/ftp/pub/
drwxrwxrwx. root root system_u:object_r:public_content_t:s0 /var/ftp/pub/
[root@localhost~]# chcon -R -t public_content_rw_t /var/ftp/pub/
[root@localhost~]# ls -ldZ /var/ftp/pub/
drwxrwxrwx. root root system_u:object_r:public_content_rw_t:s0 /var/ftp/pub/

#Selinux的问题就解决了,现在我们再来上传文件

lftp 192.168.168.105:/> ls
drwx------    2 14       50              6 Sep 12 14:28 lala
drwxrwxrwx    2 0        0               6 Aug 03  2017 pub
lftp 192.168.168.105:/> cd pub/
lftp 192.168.168.105:/pub> ls inittab
lftp 192.168.118.100:/pub> put /etc/inittab 
491 bytes transferred
lftp 192.168.168.105:/pub> ls
-rw------- 

#匿名用户就可以上传文件了。

#总结,开放匿名用户的上传文件的权限的解决方法

1,开启目录自身的权限

2,开启服务控制的权限

#3,解决selinux的问题

lftp 192.168.168.105:/pub> rm inittab 
rm: Access failed: 550 Permission denied. (inittab)

#没有删除文件的权限

用户访问

#本地用户访问ftp服务,新建用户ftp_test


[root@localhost~]# useradd ftp_test
[root@localhost~]# echo "123"|passwd --stdin ftp_test

#更改用户 ftp_test 的密码 。
passwd:所有的身份验证令×××已经成功更新。

#客户端验证

[root@client ~]# lftp 192.168.168.105
lftp 192.168.118.100:~> login ftp_test 123
lftp ftp_test@192.168.118.100:~> mkdir ftp
mkdir 成功, 建立 `ftp'    

#服务端查看

[root@localhost ~]# ls /home/ftp_test/
ftp

锁定所有本地⽤用户只能在⾃自⼰己的家⽬目录操作

chroot_local_user=YES #在配置文件里面加入此条
1
虚拟用户配置如下:

#创建文本格式的用户名,密码列表,例添加两个用户tom,jerry,密码为123,456

[root@ftp-server ~]# touch /etc/vsftpd/vu.list
[root@ftp-server ~]# echo 'tom' >> /etc/vsftpd/vu.list
[root@ftp-server ~]# echo '123' >> /etc/vsftpd/vu.list
[root@ftp-server ~]# echo 'jerry' >> /etc/vsftpd/vu.list
[root@ftp-server ~]# echo '456' >> /etc/vsftpd/vu.list
[root@ftp-server ~]# cat /etc/vsftpd/vu.list
tom
123
jerry
456

#用户名和密码一一对应,前面是账号,后面跟密码

安装db4工具

[root@ftp-server ~]# yum -y install db4*

#将刚创建的文本格式的用户名,密码文件使用db4工具转换为数据库文件

[root@ftp-server ~]# db_load -T -t hash -f /etc/vsftpd/vu.list /etc/vsftpd/vu.db

#为提高虚拟用户账号文件的安全性,应将文件权限设置为600,以避免数据外泄

[root@localhost ~]# chmod 600 /etc/vsftpd/vu.*
[root@localhost ~]#  ll /etc/vsftpd/vu.*
-rw-------. 1 root root 12288 9月  13 02:38 /etc/vsftpd/vu.db
-rw-------. 1 root root    18 9月  13 02:37 /etc/vsftpd/vu.list

#添加虚拟用户的映射账号,创建ftp目录,例如要将使用的ftp根目录设置为/var/ftproot,映射账号的名称为vftp,可以执行以下操作

[root@localhost ~]#  useradd -d /var/ftproot -s /sbin/nologin vftp
[root@localhost ~]# chmod 755 /var/ftproot/
[root@localhost ~]#  ll -d /var/ftproot/
drwxr-xr-x. 3 vftp vftp 78 9月  13 02:39 /var/ftproot/

#为虚拟用户建立PAM认证

[root@localhost ~]# cp /etc/pam.d/vsftpd /etc/pam.d/vsftpd.bak
[root@localhost ~]# vim /etc/pam.d/vsftpd

#将配置文件内容全部删除,只留3行内容

#%PAM-1.0
auth required pam_userdb.so db=/etc/vsftpd/vu
account required pam_userdb.so db=/etc/vsftpd/vu

#修改vsftpd配置文件,添加虚拟用户支持

[root@localhost ~]# echo 'guest_enable=YES' >> /etc/vsftpd/vsftpd.conf
[root@localhost ~]# echo 'guest_username=vftp' >> /etc/vsftpd/vsftpd.conf

#为不同的虚拟用户建立独立的配置文件

[root@localhost ~]# echo 'user_config_dir=/etc/vsftpd/vusers_dir' >> /etc/vsftpd//vsftpd.conf 
[root@localhost ~]# echo 'allow_writeable_chroot=YES' >> /etc/vsftpd/vsftpd.conf 

#有了这些配置之后,就可以在/etc/vsftpd/vusers_dir目录中为没个虚拟用户分别建立配置文件了

#设置tom用户能够上传文件,创建目录

[root@localhost ~]# mkdir /etc/vsftpd/vusers_dir
[root@localhost~]# ll /etc/vsftpd/
总用量 40
-rw-------. 1 root root   125 8月   3 2017 ftpusers
-rw-------. 1 root root   361 8月   3 2017 user_list
-rw-r--r--. 1 root root    27 9月  13 02:41 vsftpd.
-rw-------. 1 root root  5133 9月  13 02:42 vsftpd.conf
-rwxr--r--. 1 root root   338 8月   3 2017 vsftpd_conf_migrate.sh
-rw-------. 1 root root 12288 9月  13 02:38 vu.db
-rw-------. 1 root root    18 9月  13 02:37 vu.list
drwxr-xr-x. 2 root root     6 9月  13 02:42 vusers_dir
[root@ftp-server ~]# echo 'anon_upload_enable=YES' >> /etc/vsftpd/vusers_dir/tom
[root@ftp-server ~]# echo 'anon_mkdir_write_enable=YES' >> /etc/vsftpd/vusers_dir/tom 

#重启服务

[root@localhost ~]# systemctl restart vsftpd
1

#客户端验证tom权限

[root@localhost ~]# lftp 192.168.118.128
lftp 192.168.118.128:~> login tom 123     #登录到tom用户

lftp tom@192.168.118.100:/> mkdir aa      #创建文件aa成功
mkdir 成功, 建立 `aa'
lftp tom@192.168.118.100:/> ls
drwx------    2 1001     1001            6 Sep 13 03:04 aa
lftp tom@192.168.118.100:/> rm aa        #不能删除文件aa,没有删除权限
rm: Access failed: 550 Permission denied. (aa)
lftp tom@192.168.118.100:/> put /etc/inittab   #上传文件inittab成功
491 bytes transferred
lftp tom@192.168.118.100:/> ls
drwx------    2 1001     1001            6 Sep 13 03:04 aa
-rw-------    1 1001     1001          491 Sep 13 03:11 inittab
lftp tom@192.168.118.100:/> get TeamViewer_Setup-13.1.3629.0.exe
20367104 bytes transferred          #下载文件成功

#设置jerry用户的默认下载权限,创建jerry的空文件

[root@ftp-server ~]# touch /etc/vsftpd/vusers_dir/jerry
1

#客户端验证

[root@ftp-client ~]# lftp -u jerry,456 192.168.118.100                                 #登录虚拟用户jerry
lftp jerry@192.168.118.100:~> ls
-rw-r--r--    1 0        0        20367104 Aug 30 13:02 TeamViewer_Setup-13.1.3629.0.exe
drwx------    2 1001     1001            6 Sep 13 03:04 aa
-rw-------    1 1001     1001          491 Sep 13 03:11 inittab
lftp jerry@192.168.118.100:/> mkdir haha    #没有创建文件的权限,创建失败
mkdir: Access failed: 550 Permission denied. (haha)
lftp jerry@192.168.118.100:/> get TeamViewer_Setup-13.1.3629.0.exe
20367104 bytes transferred     #下载文件成功      

转载于:https://blog.51cto.com/13945839/2284672

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值