vsftpd服务虚拟用户配置

所谓虚拟用户就是没有使用真实的帐户,但ftp登录需要一个用户身份,这个时候我们可以给它创建一个用户,专门来给这些虚拟的用户用ok拉。

建立虚拟用户:

         useradd -d /home/ftpsite virtual

         chown virtual.virtual /home/ftpsite

 

修改/etc/vsftpd.conf文件:

                  local_enable=YES     设定本地用户可以访问。注:如使用虚拟宿主用户,在该项目设定为NO的情况下所有虚拟用户将无法访问。
                  chroot_list_enable=YES 使用户不能离开主目录
                   xferlog_file=/var/log/vsftpd.log 设定vsftpd的服务日志保存路径。注意,该文件默认不存在。必须要手动touch出来
                   ascii_upload_enable=YES
                   ascii_download_enable=YES 设定支持ASCII模式的上传和下载功能。

 

                  //以下这一步很重要,是虚拟用户的事情,哈哈
                   pam_service_name=vsftpd PAM认证文件名。PAM将根据/etc/pam.d/vsftpd进行认证
 
                   guest_enable=YES 设定启用虚拟用户功能。
                    guest_username=virtual 指定虚拟用户的宿主用户,就是上面建立的用户
                    user_config_dir=/etc/vsftpd_user_conf    所有用户的配置目录

 

  认证模块:

                  装Berkeley DB数据库    db4.8-utils;

                  apt-get install  db4.8-utils

 

                 然后,创建用户密码文本/etc/vuser_passwd.txt ,奇行是用户名,偶行是密码
                    test
                    testpass
                    ftpuser2
                    ftppass2
                接着,.生成虚拟用户认证的db文件
                      db4.8_load -T -t hash -f /etc/vuser_passwd.txt /etc/vuser_passwd.db

 

                随后,编辑认证文件/etc/pam.d/vsftpd,全部注释掉原来语句
               再增加以下两句
                  auth required pam_userdb.so db=/etc/vuser_passwd
                  account required pam_userdb.so db=/etc/vuser_passwd

             创虚拟用户配置文件
              mkdir /etc/vsftpd_user_conf/
               vi /etc/vsftpd_user_conf/test
             内容如下:
                  local_root=/opt/var/ftp1 虚拟用户的根目录(根据实际修改)
                 write_enable=YES 可写
                anon_umask=022 掩码
                anon_world_readable_only=NO
                anon_upload_enable=YES
               anon_mkdir_write_enable=YES
               anon_other_write_enable=YES

            改变/opt/var/ftp1这个目录的权限

            chown virtual:virtual  /opt/var/ftp1

 

    启动vsftpd:

                 service vsftpd  start

 

 

wyt@wyt-laptop:~$ ftp 192.168.1.15
Connected to 192.168.1.15.
220 (vsFTPd 2.0.7)
Name (192.168.1.15:wyt): test
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> ls
200 PORT command successful. Consider using PASV.
150 Here comes the directory listing.
-rw-r--r--    1 107      0               4 Aug 20 04:54 msg
226 Directory send OK.

 

 

出现错误

500 OOPS: vsftpd: cannot locate user specified in 'ftp_username':ftpabcd
在vsftpd.conf中加入了ftp_username=xxx(用户)

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
安装和配置vsftpd服务器并设置虚拟用户的步骤如下: 1. 安装vsftpd服务器: 在Ubuntu终端中运行以下命令安装vsftpd服务器: ``` sudo apt-get update sudo apt-get install vsftpd ``` 2. 配置vsftpd服务器: 打开vsftpd配置文件: ``` sudo nano /etc/vsftpd.conf ``` 3. 修改以下配置项: - 启用虚拟用户功能,将以下行取消注释并修改为: ``` virtual_use_local_privs=YES guest_enable=YES guest_username=ftp user_sub_token=$USER local_root=/home/ftp/$USER chroot_local_user=YES hide_ids=YES ``` - 禁用匿名访问,将以下行取消注释并修改为: ``` anonymous_enable=NO ``` - 允许写入权限,将以下行取消注释并修改为: ``` write_enable=YES local_umask=022 file_open_mode=0777 ``` 4. 保存并关闭文件。 5. 创建虚拟用户: 创建一个系统用户用于管理虚拟用户: ``` sudo adduser ftp ``` 6. 创建虚拟用户配置文件: 创建一个文件来存储虚拟用户用户名和密码: ``` sudo nano /etc/vsftpd/virtual_users.txt ``` 7. 在文件中添加虚拟用户用户名和密码,每行一个用户,格式为`用户名:密码`,例如: ``` user1:password1 user2:password2 ``` 8. 保存并关闭文件。 9. 生成虚拟用户数据库文件: 运行以下命令生成虚拟用户数据库文件: ``` sudo db_load -T -t hash -f /etc/vsftpd/virtual_users.txt /etc/vsftpd/virtual_users.db ``` 10. 设置权限: 运行以下命令设置虚拟用户数据库文件的权限: ``` sudo chmod 600 /etc/vsftpd/virtual_users.db ``` 11. 重启vsftpd服务: 运行以下命令重启vsftpd服务以使配置生效: ``` sudo service vsftpd restart ``` 现在,您已经成功安装和配置vsftpd服务器,并设置了虚拟用户

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值