Ubuntu上vsftpd安装与多用户目录配置

2023-10-29

vsftpd安装与多用户目录配置

文章配置使用Ubuntu进行配置,CentOS系统的配置也是大同小异,主要理解虚拟用户的加载方式和权限目录的配置

 

配置目标:

在/home/vsftpd 目录下有3个子目录分别为folder1,folder2,folder3

三个子目录分别为三个虚拟用户user1,user2,user3的ftp主目录,并且每个用户只能在自己的子目录下有权限操作。三个用户的密码分别为pwd_user1,pwd_user2,pwd_user3

 

目录

一、安装vsftpd. 2

1、530 Login incorrect问题... 2

2.、解决530,修改禁止用户登录的文件... 3

3、解决530,修改配置shell 3

二、安装db-util工具... 4

三、配置根目录以及虚拟用户数据库... 5

1、创建根目录... 5

2、创建虚拟用户数据库... 6

四、修改配置PAM文件... 7

五、为虚拟用户创建本地系统用户... 8

六、配置vsftpd的主配置文件... 8

七、配置每个虚拟用户的权限... 9

八、测试vsftpd. 10

1、使用第三方工具连接... 10

2、测试根目录文件下载... 11

3、测试根目录文件上传... 11

4、测试非根目录文件下载... 12

5、测试非根目录文件上传... 13

九、添加新的ftp账户指定单独的根目录... 14

1. 添加账户名和密码... 14

2、重新生成用户数据库文件... 14

3、创建新增账户根目录... 15

4、创建新用户权限文件... 16

5、重启vsftpd. 17

十、vsftpd配置文件详细说明... 19

十一、常用命令... 20

十二、完全卸载vsftpd. 20

 

 

 

一、安装vsftpd

sudo apt-get install vsftpd

1、530 Login incorrect问题

直接使用本地的root账户登录,查看是否安装成功

ftp localhost

使用本地的root账户登录以后遇到530 Login incorrect问题导致Login failed(登录失败)

解决方案:

查看vsftpd安装的所有文件,因为是使用apt-get install直接安装的,所以可以使用命令:

dpkg -L vsftpd

配置文件基本看/etc目录下的文件就好,其中各个文件的基本作用:

/etc/ftpusers                #禁止登录的用户文件,每行表示一个用户名

/etc/init.d/vsftpd         #vsftpd的命令文件,比如/etc/init.d/vsftpd status(查看状态)

/etc/logrotate.d/vsftpd       #日志文件

/etc/pam.d/vsftpd              #用于配置用户的登录shell和加载禁止登录的用户文件

/etc/vsftpd.conf                  #vsftpd的主配置文件

 

2.、解决530,修改禁止用户登录的文件

出现530 Login incorrect原因可以先查看当前账户是否在禁止用户登录的文件中

编辑文件/etc/ftpusers

vim /etc/ftpusers

将登录出错的root账户注释掉

尝试登录

登录成功,如果是虚拟用户还是登录失败,还得接着修改配置shell。

 

3、解决530,修改配置shell

通常我们在创建vsftpd的虚拟用户时,为了禁止虚拟用户通过ssh登录主机,通常会设置登录的shell为/bin/false 、/usr/sbin/nologin 等。

查看主机系统的登录shell

cat /etc/shells

由此可见我们设置的虚拟用户的登录shell在系统登录shell列表中根本不存在,此时该虚拟用户不能登录就在正常不过了,但是又要能够让该虚拟用户嫩能够登录vsftpd,此时可以修改vsftpd配置登录shell的文件/etc/pam.d/vsftpd

vim /etc/pam.d/vsftpd

当前登录方式使用的是pam_shells.so,通过了主机系统的/etc/shells验证,所以将pam_shells.so修改就好了,修改为pam_nologin.so即可

保存退出,重启vsftpd,

service vsftpd restart

或者

/etc/init.d/vsftpd restart

重启完整之后进行登录。

 

二、安装db-util工具

db_util工具的用途是将用户文件转化为数据库文件

sudo apt-get install db-util

 

三、配置根目录以及虚拟用户数据库

1、创建根目录

在/home目录下创建vsftpd目录并在vsftpd目录下创建三个子目录folder1,folder2,folder3

注意:虚拟账户对ftp的根目录是没有写入权限的,如果需要写入权限需要在根目录下创建一个子目录,并授权777

进入folder1目录,创建子目录test

cd folder1/

创建测试目录:

mkdir test

修改子目录所属和所属组

chown ftpUser:ftpUser test/

修改子目录权限为当前能登录操作所有权限

chmod 777 test/

在根目录folder1放入测试文件readme.txt

在新建的test目录下放入测试文件readme.txt文件

其他三个目录也是类似如此操作。

 

2、创建虚拟用户数据库

创建文本文件loguser.txt

格式如下:

user_id

password

 

注意:奇数行为账户名,偶数行为密码。也就是1.3.5.等行为用户名,2.4.6行为密码;

最后一行需要回车(否则建立数据库文件时无法识别最后一行,导致报奇数行错误)

cd /home/            #切换到home目录

vim loguser.txt      #创建文件loguser.txt

user1

pwd_user1

user2

pwd_user2

user3

pwd_user3

 

 

编辑完成保存,退出

生成数据库文件

使用db_load命令将用户生成数据库放到/etc目录下

sudo db_load -T -t hash -f /home/loguser.txt /etc/vsftpd_login.db

授权生成的数据文件

sudo chmod 600 /etc/vsftpd_login.db

查看/etc/vsftpd_login.db文件的权限

ll /etc/vsftpd_login.db

 

四、修改配置PAM文件

将创建的用户数据文件在/etc/pam.d/vsftpd文件中调用,虚拟用户将采用PAM进行验证。

在vsftpd的主配置文件/etc/vsftpd.conf文件中的 语句pam_service_name=vsftpd就是用来配置启用pam.d下的文件

编辑文件/etc/pam.d/vsftpd 将以下内容增加到原文件前面两行:

auth sufficient pam_userdb.so db=/etc/vsftpd_login

account sufficient pam_userdb.so db=/etc/vsftpd_login

vim /etc/pam.d/vsftpd

编辑完成保存退出。

 

五、为虚拟用户创建本地系统用户

新建一个系统用户ftpUser,用户家目录为/home/vsftpd, 用户登录终端设为/bin/false(这样能禁止该用户通过ssh登录系统)

新建ftpUser用户

sudo useradd ftpUser -d /home/vsftpd -s /bin/false

授权目录/home/vsftpd的文件所有者

sudo chown ftpUser:ftpUser /home/vsftpd -R

 

六、配置vsftpd的主配置文件

根据需要配置/etc/vsftpd.conf,一般设置:

 

listen=YES

anonymous_enable=NO

local_enable=YES

dirmessage_enable=YES

use_localtime=YES

xferlog_enable=YES

connect_from_port_20=YES

xferlog_file=/var/log/vsftpd.log

xferlog_std_format=YES

ftpd_banner=Welcome to blah FTP service.

chroot_local_user=YES

guest_enable=YES

user_config_dir=/etc/vsftpd_user_conf

secure_chroot_dir=/var/run/vsftpd/empty

pam_service_name=vsftpd

rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem

rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key

ssl_enable=NO

utf8_filesystem=YES

编辑文件/etc/vsftpd.conf

编辑完成保存退出,重启vsftpd

 

七、配置每个虚拟用户的权限

在vsftpd的主配置文件/etc/vsftpd.conf中配置了user_config_dir=/etc/vsftpd_user_conf

所以需要把各个用户的配置文件放到/etc/vsftpd_user_conf目录下

注意:每个用户的配置文件需要以用户名进行命名

创建/etc/vsftpd_user_conf目录

mkdir /etc/vsftpd_user_conf

创建用户对应的配置文件

user1

user2

user3

切换目录到/etc/vsftpd_user_conf/

cd /etc/vsftpd_user_conf/

创建文件user1,user2,user3

touch {user1,user2,user3}

编辑user1,填入以下内容

write_enable=YES      #是否开放本地用户的写权限

anon_world_readable_only=NO    #是否开放匿名用户的浏览权限

anon_upload_enable=YES    #设置是否允许匿名用户上传

anon_mkdir_write_enable=YES    #设置是否允许匿名用户创建目录

anon_other_write_enable=YES    #设置是否允许匿名用户其他的写权限

local_root=/home/vsftpd/folder1    #设置用户根目录

 

注意:在vim中编辑时每一行的结尾都不能出现空格,保证最后一个字母就是该行的结尾,如果出现空格,登录时报错

500 OOPS: bad bool value in config file for: guest_enable Login failed. 或者

500 OOPS: bad bool value in config file for: anon_upload_enable Login failed.

编辑user2,填入以下内容

write_enable=YES

anon_world_readable_only=NO

anon_upload_enable=YES

anon_mkdir_write_enable=YES

anon_other_write_enable=YES

local_root=/home/vsftpd/folder2

 

编辑user3,填入以下内容

write_enable=YES

anon_world_readable_only=NO

anon_upload_enable=YES

anon_mkdir_write_enable=YES

anon_other_write_enable=YES

local_root=/home/vsftpd/folder3

 

配置完成重启vsftpd

service vsftpd restart

 

八、测试vsftpd

1、使用第三方工具连接

使用第三方ftp连接工具FileZilla进行连接

连接成功,自动获取到user1账户的根目录列表

2、测试根目录文件下载

将根目录中的readme.txt文件下载到本地,双击ftp服务器上的readme.txt文件,文件执行下载

根目录文件下载成功

3、测试根目录文件上传

将本地的test.txt文件上传到ftp服务器user1账户的根目录下,双击本地test.txt文件,文件执行上传

文件上传失败,因为ftp用户不能对根目录有写的权限,当然也不能在根目录创建子目录

4、测试非根目录文件下载

进入根目录下的子目录test目录下,

下载目录中的readme.txt文件到本地

文件下载成功

 

5、测试非根目录文件上传

在非ftp用户根目录的子目录test目录中,将本地test.txt文件进行上传

文件上传成功,说明ftp账户对非根目录存在写入权限,当然此时也可以创建目录了(在用户权限配置文件/etc/vsftpd_user_conf/user1中权限允许的情况下)

 

九、添加新的ftp账户指定单独的根目录

1. 添加账户名和密码

添加账户名为:test

密码为:123456

根目录为:/home/vsftpd/test

 

编辑/home/loguser.txt文件,将新的账户添加到文件中,注意保证最后一行为空行

编辑完成保存退出

 

2、重新生成用户数据库文件

使用覆盖的方式重新生成新的数据文件,如果不使用覆盖的方式生成用户数据文件,那么就需要去修改/etc/pam.d/vsftpd文件中指定的用户数据文件路径

使用覆盖的方式重新生成用户数据文件

之前生成的用户数据文件目录为/etc/vsftpd_login.db

备份源文件

重新生成用户数据文件

sudo db_load -T -t hash -f /home/loguser.txt /etc/vsftpd_login.db

如果没有使用替换的方式生成新的用户数据文件,则需要修改文件/etc/vsftpd_login.db文件中指定的路径

 

3、创建新增账户根目录

在已有的/home/vsftpd目录中创建test目录

更改文件的所有者和所属组

chown ftpUser:ftpUser test/

进入test目录(当前账户的根目录,根目录下仅有可读权限),在test目录下创建一个测试文件test1.txt

在目录test中创建一个ftp账户拥有所有权的目录temp

mkdir temp

更改文件的所有者和所属组

chown ftpUser:ftpUser temp/

chown ftpUser:ftpUser test1.txt

授权temp目录777权限

chmod 777 temp/

进入temp目录创建测试文件

cd temp/

vim test2.txt

 

4、创建新用户权限文件

在/etc/vsftpd_user_conf目录中以用户名称为文件名创建用户权限文件

并写入相应权限

write_enable=YES

anon_world_readable_only=NO

anon_upload_enable=YES

anon_mkdir_write_enable=YES

anon_other_write_enable=YES

local_root=/home/vsftpd/test

vim test

写入完成保存,退出

 

5、重启vsftpd

重启vsftpd

service vsftpd restart

查看状态

service vsftpd restart

启动正常。

使用三方工具FileZilla进行连接测试

ftp账户名:test

ftp账户密码:123456

进入temp目录执行上传下载操作测试

上传下载均操作成功

 

十、vsftpd配置文件详细说明

 

listen=<YES/NO> :设置为YES时vsftpd以独立运行方式启动,设置为NO时以xinetd方式启动(xinetd是管理守护进程的,将服务集中管理,可以减少大量服务的资源消耗)

listen_port=<port> :设置控制连接的监听端口号,默认为21

listen_address=<ip address> :将在绑定到指定IP地址运行,适合多网卡

connect_from_port_20=<YES/NO> : 默认为YES,FTP-DATA数据传送使用port 20,

pasv_enable=<YES/NO> :是否使用被动模式,如果客户机在防火墙后,请开启为YES

pasv_min_port=<n>

pasv_max_port=<m> :设置被动模式的连接端口范围在n和m之间,例,50000-60000

message_file=<filename> :设置使用者进入某个目录时显示的文件内容,默认为 .message

dirmessage_enable=<YES/NO> :设置使用者进入某个目录时是否显示由message_file指定的文件内容

ftpd_banner=<message> :设置用户连接服务器后的显示信息,就是欢迎信息

banner_file=<filename> :设置用户连接服务器后显示信息存放在指定的filename文件中

connect_timeout=<n> :如果客户机连接服务器超过N秒,则强制断线,默认60

accept_timeout=<n> :当使用者以被动模式进行数据传输时,服务器发出passive port指令等待客户机超过N秒,则强制断线,默认60

accept_connection_timeout=<n> :设置空闲的数据连接在N秒后中断,默认120

data_connection_timeout=<n> : 设置空闲的用户会话在N秒后中断,默认300

max_clients=<n> : 在独立启动时限制服务器的连接数,0表示无限制

max_per_ip=<n> :在独立启动时限制客户机每IP的连接数,0表示无限制

local_enable=<YES/NO> :设置是否支持本地用户帐号访问

guest_enable=<YES/NO> :设置是否支持虚拟用户帐号访问

write_enable=<YES/NO> :是否开放本地用户的写权限

local_umask=<nnn> :设置本地用户上传的文件的生成掩码,默认为077

local_max_rate<n> :设置本地用户最大的传输速率,单位为bytes/sec, 0表示不限制

local_root=<file> :设置本地用户登陆后的目录,默认为本地用户的主目录

chroot_local_user=<YES/NO> :当为YES时,所有本地用户可以执行chroot

chroot_list_enable=<YES/NO>

chroot_list_file=<filename> :当chroot_local_user=NO 且 chroot_list_enable=YES时,只有filename文件指定的用户可以执行chroot

anonymous_enable=<YES/NO> :设置是否支持匿名用户访问

anon_max_rate=<n> :设置匿名用户的最大传输速率,单位为B/s,值为0表示不限制

anon_world_readable_only=<YES/NO> 是否开放匿名用户的浏览权限

anon_upload_enable=<YES/NO> 设置是否允许匿名用户上传

anon_mkdir_write_enable=<YES/NO> :设置是否允许匿名用户创建目录

anon_other_write_enable=<YES/NO> :设置是否允许匿名用户其他的写权限(注意,这个在安全上比较重要,一般不建议开,不过关闭会不支持续传)

anon_umask=<nnn> :设置匿名用户上传的文件的生成掩码,默认为077

 

 

十一、常用命令

1、启动Vsftpd服务其命令为:

service vsftpd start

/etc/init.d/vsftpd start

 

2、停止Vsftpd服务的命令为:

service vsftpd stop

/etc/init.d/vsftpd stop

 

3、重新启动Vsftpd服务的命令为:

service vsftpd restart

/etc/init.d/vsftpd restart

 

4、检查Vsftpd服务的运行状态:

service vsftpd status

/etc/init.d/vsftpd status

 

十二、完全卸载vsftpd

apt-get remove --purge vsftpd

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Ubuntu上vsftpd安装与多用户目录配置 的相关文章

  • 【Mac】mac安装redis客户端 Error: Cask ‘rdm‘ is unavailable: No Cask with this name exist

    1 概述 mac安装redis客户端 rdm 报错如下 lcc lcc brew cask install rdm Updating Homebrew Error Cask rdm is unavailable No Cask with t
  • java——线程池

    一 线程池 线程池可以看做是线程的集合 它的工作主要是控制运行的线程的数量 处理过程中将任务放入队列 然后在线程创建后 启动这些任务 如果线程数量超过了最大数量超出数量的线程排队等候 等其它线程执行完毕 再从队列中取出任务来执行 他的主要特
  • 重写equal()时为什么也得重写hashCode()之深度解读equal方法与hashCode方法渊源

    今天这篇文章我们打算来深度解读一下equal方法以及其关联方法hashCode 我们准备从以下几点入手分析 1 equals 的所属以及内部原理 即Object中equals方法的实现原理 说起equals方法 我们都知道是超类Object
  • Android Hierarchy Viewer

    Android的SDK工具包中 有很多十分有用的工具 可以帮助程序员开发和测试Android应用程序 大大提高其工作效率 其中的一款叫Hierachy Viewer的可视化调试工具 可以很方便地帮助开发者分析 设计 调试和调整UI界面 提高

随机推荐

  • 高斯低通频率域滤波

    基本原理 频率域滤波 即将原图像通过傅里叶变换 转换至频率域 在频率域利用该域特有的性质进行处理 再通过傅里叶反变换把处理后的图像返回至空间域 所以 频率域的操作是在图像的傅里叶变换上执行 而不是在图像本身上执行 高斯低通滤波器传递函数表达
  • 跟着 iLogtail 学习设计模式

    设计模式是软件开发中的重要经验总结 Gang of Four GoF 提出的经典设计模式则被誉为设计模式中的 圣经 但是设计模式往往是以抽象和理论化的方式呈现 对于初学者或者没有太多实战经验的开发者来说 直接学习设计模式往往会显得枯燥乏味
  • c++ parse html,c++ - QT parse html to txt file - Stack Overflow

    I think it s always best if you actually attempt at something and post up your code to serve as a starting point But I m
  • 小径

    尽入夏 绕竹篱 已是桃花稀落 笑到西川 此去随所遇 不羡青山不拜仙 园中花草 草木香幽 清风独得朝暮暖 蕲水携来四季春 云岩宫阙 尽是人间 峰峦断却处 本是一脉之水 两侧命不相同 一水之门 几多思量 几多判却 一方玲珑剔透 嬉水无痕 一方藻
  • 计算机网络——第四章

    网络层 主要任务是把分组从源端传送到目的端 为分组交换网上的不同主机提供通信服务 传输单位是数据报 功能 1 路由选择与分组转发 2 异构网络互联 3 拥塞控制 若所有节点都来不及接受分组 而要丢弃大量分组的话 网络就处于拥塞状态 因此要采
  • python数据库-NumPy与Matplotlib库

    NumPy 1 导入numpy库 import numpy as np python中用import导入库 这里的意思是将怒骂朋友作为np导入 通过这样的形式 之后使用numpy相关方法用np使用 2 生成numpy数组 import nu
  • LeetCode--数组类算法:删除排序数组中的重复项 II

    题目 给定一个排序数组 你需要在原地删除重复出现的元素 使得每个元素最多出现两次 返回移除后数组的新长度 不要使用额外的数组空间 你必须在原地修改输入数组并在使用 O 1 额外空间的条件下完成 示例一 给定 nums 1 1 1 2 2 3
  • 梳理webpack

    一 入门 1 项目初始化 新建一个目录 初始化npm npm init 此时会需要填入一些项目的基本描述 webpack是运行在node环境中的 我们需要安装以下两个npm包 npm i D webpack webpack cli 生成no
  • 【mcuclub】扫码枪-(型号:M100(1D)-TTL)(型号:GM861S)

    一 实物图 型号 M100 1D TTL 只能扫描一维条形码 二 原理图 编号 名称 功能 1 VCC 电源正 2 GND 电源地 3 TXD 串口数据发送引脚 接单片机上的RX引脚 4 RXD 串口数据接收引脚 接单片机上的TX引脚 三
  • Unity 处理mono内存(堆内存)泄露问题

    先讲解一下mono特性 一个很重要的信息 mono内存从系统里面申请的内存不会返回给系统 mono内存不足的时候会预申请内存 内存大小不定有可能10m有可能5m 最近优化一个mono内存泄露问题 引起mono一直撑大多数都是内存泄露 要不就
  • ArrayBlockingQueue和LinkedBlockingQueue

    ArrayBlockingQueue ArrayBlockingQueue是一个用数组实现的有界阻塞队列 其是线程安全的 内部通过 互斥锁 保护竞争资源 此队列按照先进先出 FIFO 的原则对元素进行排序 队列的头部是在队列中存在时间最长的
  • el-tabs组件切换之前拦截函数异常踩坑记录

    背景 产品需求在离开当前tab之前要对页面填写信息进行校验 若没有任何改动则可以直接切换tab 若有改动 则需要在跳转之前进行拦截 提示用户 当前页面信息未保存 确定离开吗 确定或取消由用户选择 代码实现
  • 逆向工程核心原理——DLL注入——创建远程线程

    什么是DLL注入 dll注入是一种将Windows动态链接库注入到目标进程中的技术 具体的说 就是将dll文件加载到一个进程的虚拟地址空间中 对某个进程进行dll注入 也就意味着dll模块与该进程共用一个进程空间 则这个dll文件就有了操纵
  • 可变频率正弦信号发生器的FPGA实现(Quartus)

    一 说明 实现平台 Quartus17 1 MATLAB2021a和Modelsim SE 64 10 4 二 内容 1 产生一个完整周期的正弦波信号 并保存为 mif文件 2 设计一个ROM 将正弦波信号文件初始化如该ROM中 3 设计一
  • 内存分配---kmalloc

    kmalloc 内存分配引擎是一个功能强大的工具 下面我们来讲解一下这个函数 Kmalloc 函数分配内存时有几个特点 1 获取内存空间时不会对内存空间进行清零 也就是说 分配给它的区域仍然保持着原有的数据 2 它分配的区域在物理内存中也是
  • Ubuntu中火狐浏览器Firefox打不开网页

    浏览器地址栏输入 about config 搜索 general useragent override 无则新建 输入字符串 Mozilla 5 0 X11 Linux x86 64 AppleWebKit 537 36 KHTML lik
  • 2021-09-02防火墙和CDN、Ajax跨域

    欢迎大家一起来Hacking水友攻防实验室学习 渗透测试 代码审计 免杀逆向 实战分享 靶场靶机 求关注 CDN 内容分发网络 Content Delivery Network 简称CDN 是建立并覆盖在承载网之上 由分布在不同区域的边缘节
  • 如何查看mac系统是32位还是64位的操作系统

    一 点击工具栏左上角点击 苹果Logo 标志 关于本机 gt 更多信息 gt 系统报告 gt 左侧栏中 软件 二 打开终端 输入命令 uname a 回车 x86 64 表示系统为64位 i686 表示系统32位的 比如我的 三 在终端输入
  • js实现模糊搜索

    功能一 关键字搜索 总结 1 搜索出的结果 前台先要清空原有表格 tbody empty 2 后台返回的json格式字符串 js eval 专成对象var stus eval msg 在循环进行字符串拼接到表格上 tbody html st
  • Ubuntu上vsftpd安装与多用户目录配置

    vsftpd安装与多用户目录配置 文章配置使用Ubuntu进行配置 CentOS系统的配置也是大同小异 主要理解虚拟用户的加载方式和权限目录的配置 配置目标 在 home vsftpd 目录下有3个子目录分别为folder1 folder2