当前位置: 代码网 > it编程>游戏开发>ar > 【centos】【vsftpd】FTP本地用户登录配置

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

2024年08月03日 ar 我要评论
描述:本机ftp测试没问题;内网其他服务器ftp登陆成功,但执行ls等命令报错。原因:安装的最新版本,增加了对配置错误的强制检查,要求根目录不可写。文件,对以下两条要求进行排查,我的用户是。重启验证,该报错解决,但登录时出现先报错。默认访问目录/home/ftpuser。默认ipv6,可修改为ipv4配置。仅本地用户ftpuser可访问。仅本地用户ftptest可访问。仅可访问目录/var/ftp。安全增强模块,根据情况修改。文件,然后写入本地用户。原因:被动模式端口问题。

ftp与sftp

安装vsftpd和ftp

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

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

  1. 新增本地用户ftpuser

    useradd -d /home/ftpuser -s /bin/bash ftpuser
    passwd ftpuser
    
  2. 修改配置
    /etc/vsftpd/vsftpd.conf默认配置如下

    anonymous_enable=yes
    local_enable=yes
    write_enable=yes
    local_umask=022
    dirmessage_enable=yes
    xferlog_enable=yes
    connect_from_port_20=yes
    xferlog_std_format=yes
    listen=no
    listen_ipv6=yes
    pam_service_name=vsftpd
    userlist_enable=yes
    tcp_wrappers=yes
    

    修改后

    anonymous_enable=no #禁止匿名用户登录服务器
    local_enable=yes #允许本地用户登录服务器
    write_enable=yes #允许写操作
    local_umask=022 
    dirmessage_enable=yes
    xferlog_enable=yes
    connect_from_port_20=yes
    xferlog_std_format=yes
    listen=no
    listen_ipv6=yes
    pam_service_name=vsftpd
    userlist_enable=yes
    tcp_wrappers=yes
    
    # yes,user_list用户为黑名单,禁止登录;no则为白名单,可登录
    userlist_deny=yes
    # chroot_list本地用户可登录ftp名单,且本地用户需要在/etc/shells范围内或者修改/etc/pam.d/vsftpd的pam限制
    chroot_list_enable=yes
    chroot_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 成功

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

  1. 新增本地用户ftptest
    useradd -d /var/ftp -s /sbin/nologin ftptest
    passwd ftptest
    chmod -r 777 /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=022
    dirmessage_enable=yes
    xferlog_enable=yes
    connect_from_port_20=yes
    xferlog_std_format=yes
    listen=no
    listen_ipv6=yes
    pam_service_name=vsftpd
    userlist_enable=yes
    tcp_wrappers=yes
    
    # yes,user_list用户为黑名单,禁止登录;no则为白名单,可登录
    userlist_deny=yes
    # 限制访问目录本地用户仅可访问/var/ftp
    chroot_local_user=yes
    local_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=31000
pasv_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范围内。

    [root@localhost vsftpd]# 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
    [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()

原因:安装的最新版本,增加了对配置错误的强制检查,要求根目录不可写

  • 方案一:配置文件设置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> passive
    passive mode off.
    ftp> ls
    200 port command successful. consider using pasv.
    150 here comes the directory listing.
    drwxrwxrwx    2 0        0               6 jun 09  2021 pub
    drwxr-xr-x    2 1001     1001            6 feb 20 06:05 test
    226 directory send ok.
    
  • 方案二:配置文件设置被动模式,并开放防火墙端口31000-31999
    配置
    pasv_enable=yes
    pasv_min_port=31000
    pasv_max_port=31999
    
    防火墙
    firewall-cmd --zone=public --add-port=31000-31999/tcp --permanent
    firewall-cmd --reload
    firewall-cmd --zone=public --list-ports
    

4、425 failed to establish connection. error eelftpserror: control channel transfer error 114690

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

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com