0


【centos】【vsftpd】FTP本地用户登录配置

目录

ftp与sftp

  • 差异非常大
  • ftp相当于一种网络协议,可运行在不同操作系统,默认使用21端口和20端口,明文传输且不稳定
  • sftp基于ssh,默认使用22端口,Linux自带,加密传输且稳定
  • vsftpd是用于配置ftp,与sftp无关
  • sftp无需配置,相当于ssh远程连接,本地用户使用sftp [email protected]即可

安装vsftpd和ftp

  1. ftp用于测试yum install-y vsftpd* ftp*
  2. 启动systemctl start vsftpd
  3. 防火墙开放21端口firewall-cmd --zone=public --add-port=21/tcp --permanentfirewall-cmd --reloadfirewall-cmd --zone=public --list-ports
  4. 测试systemctl status vsftpdnetstat-ntlp|grep vsftpdftp XX.XX.XX.XX 默认配置下,匿名用户登录,密码为空在这里插入图片描述

本地用户登录-不限制访问目录

不可匿名登录
禁止其他用户访问
仅本地用户ftpuser可访问
默认访问目录/home/ftpuser
可访问其他目录

  1. 新增本地用户ftpuser``````useradd-d /home/ftpuser -s /bin/bash ftpuserpasswd ftpuser
  2. 修改配置/etc/vsftpd/vsftpd.conf默认配置如下anonymous_enable=YESlocal_enable=YESwrite_enable=YESlocal_umask=022dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES修改后anonymous_enable=NO #禁止匿名用户登录服务器local_enable=YES #允许本地用户登录服务器write_enable=YES #允许写操作local_umask=022 dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES# YES,user_list用户为黑名单,禁止登录;NO则为白名单,可登录userlist_deny=YES# chroot_list本地用户可登录ftp名单,且本地用户需要在/etc/shells范围内或者修改/etc/pam.d/vsftpd的pam限制chroot_list_enable=YESchroot_list_file=/etc/vsftpd/chroot_list# 设置根目录可写allow_writeable_chroot=YES
  3. /etc/vsftpd/下新建chroot_list文件,然后写入本地用户ftpuser,一行代表一个用户
  4. 重启systemctl restart vsftpd
  5. 本机测试ftp XX.XX.XX.XX 成功

本地用户登录-限制访问目录

不可匿名登录
禁止其他用户访问
仅本地用户ftptest可访问
仅可访问目录/var/ftp

  1. 新增本地用户ftptest``````useradd-d /var/ftp -s /sbin/nologin ftptestpasswd ftptestchmod-R777 /var/ftp
  2. 修改/etc/pam.d/vsftpd,使用户可通过pam验证[root@localhost vsftpd]# vi /etc/pam.d/vsftpd#%PAM-1.0 session optional pam_keyinit.so force revoke auth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeed #auth required pam_shells.so auth include password-auth account include password-auth session required pam_loginuid.so session include password-auth
  3. 修改配置anonymous_enable=NO #禁止匿名用户登录服务器local_enable=YES #允许本地用户登录服务器write_enable=YES #允许写操作local_umask=022dirmessage_enable=YESxferlog_enable=YESconnect_from_port_20=YESxferlog_std_format=YESlisten=NOlisten_ipv6=YESpam_service_name=vsftpduserlist_enable=YEStcp_wrappers=YES# YES,user_list用户为黑名单,禁止登录;NO则为白名单,可登录userlist_deny=YES# 限制访问目录本地用户仅可访问/var/ftpchroot_local_user=YESlocal_root=/var/ftp# 设置根目录可写allow_writeable_chroot=YES
  4. 重启systemctl restart vsftpd
  5. 本机测试ftp XX.XX.XX.XX 成功

有可能影响连接的问题

pam认证

可根据情况注释

  • auth required pam_shells.so: 仅允许用户的shell是 /etc/shells文件内的shell,才能登录
  • auth required pam_listfile.so:/etc/ftpusers 中的用户禁止登陆
# cat /etc/pam.d/vsftpd#%PAM-1.0
session    optional     pam_keyinit.so    force revoke
auth       required     pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeed
auth       required     pam_shells.so
auth       include      password-auth
account    include      password-auth
session    required     pam_loginuid.so
session    include      password-auth

selinux策略

安全增强模块,根据情况修改

  • ftpd_full_access :影响创建新目录等
  • tftp_home_dir:影响ftp根目录访问等
setsebool -P tftp_home_dir 1
setsebool -P ftpd_full_access 1
systemctl restart vsftpd
# sestatus -b | grep ftp
ftpd_anon_write                             off
ftpd_connect_all_unreserved                 off
ftpd_connect_db                             off
ftpd_full_access                            on
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                               on

被动模式

pasv_enable=YES
pasv_min_port=31000pasv_max_port=31999

防火墙

firewall-cmd --zone=public --add-port=31000-31999/tcp --permanent
firewall-cmd --reload
firewall-cmd --zone=public --list-ports

ipv4和ipv6

默认ipv6,可修改为ipv4配置

listen=YES
listen_ipv6=NO

报错

1、 530 Login incorrect

  • 确认用户账密无误
  • 网上的pam_service_name=vsftpd方法无效
  • 查看/etc/pam.d/vsftpd文件,对以下两条要求进行排查,我的用户是/sbin/nologin,不在/etc/shells范围内。> > - auth required pam_shells.so: 仅允许用户的shell是 /etc/shells文件内的shell,才能登录> - auth required pam_listfile.so item=user sense=deny file=/etc/ftpusers onerr=succeed:/etc/ftpusers 中的用户禁止登陆[root@localhost vsftpd]# cat /etc/pam.d/vsftpd#%PAM-1.0session optional pam_keyinit.so force revokeauth required pam_listfile.so item=user sense=deny file=/etc/vsftpd/ftpusers onerr=succeedauth required pam_shells.soauth include password-authaccount include password-authsession required pam_loginuid.sosession include password-auth[root@localhost vsftpd]# cat /etc/shells/bin/sh/bin/bash/usr/bin/sh/usr/bin/bash- 方案一:可以修改/etc/pam.d/vsftpd注释掉 auth required pam_shells.so- 方案二:修改用户登录属性,usermod -s /bin/bash ftptest
  • 重启验证,该报错解决,但登录时出现先报错500 OOPS: vsftpd: refusing to run with writable root inside chroot(),见下条

2、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.

  • 方案一:配置文件设置allow_writeable_chroot=YES
  • 方案二:设置ftptest用户根目录不可写chmod a-w ftptest

3、227 Entering Passive Mode (10,1,58,5,242,166). ftp: connect: 没有到主机的路由

描述:本机ftp测试没问题;内网其他服务器ftp登陆成功,但执行ls等命令报错
原因:被动模式端口问题

  • 方案一:登录后,输入passive,关掉被动模式ftp> passivePassive mode off.ftp>ls200 PORT command successful. Consider using PASV.150 Here comes the directory listing.drwxrwxrwx 2006 Jun 09 2021 pubdrwxr-xr-x 2100110016 Feb 20 06:05 test226 Directory send OK.
  • 方案二:配置文件设置被动模式,并开放防火墙端口31000-31999 配置pasv_enable=YESpasv_min_port=31000pasv_max_port=31999 防火墙firewall-cmd --zone=public --add-port=31000-31999/tcp --permanentfirewall-cmd --reloadfirewall-cmd --zone=public --list-ports

4、425 Failed to establish connection. Error EElFTPSError: Control channel transfer error 114690

描述:内网正常,外网登陆成功但执行其他命令失败
原因:防火墙添加端口后,未

firewall-cmd --reload

使其生效

标签: centos linux 运维

本文转载自: https://blog.csdn.net/lorogy/article/details/136171858
版权归原作者 lorogy 所有, 如有侵权,请联系我们删除。

“【centos】【vsftpd】FTP本地用户登录配置”的评论:

还没有评论