ftp多用户多目录配置

news/2025/10/14 13:57:10/文章来源:https://www.cnblogs.com/niewd/p/19140938

ftp多用户多目录配置 

测试环境:centos7

1. 装包与卸载

yum -y install vsftpd
yum -y autoremove vsftpd&&rm -rf /etc/vsftpd /etc/pam.d/vsftpd.rpmsave

2. 用户清单配置

不要去动user_list和ftpusers文件,这个是pam的配置,后面会替换整个pam文件,所以一旦修改,会导致一些预期之外的登陆报错。
按此文配置,如果手痒添加了userlist_deny=NO,会导致用户无权访问,哪怕在user_list文件中添加了用户名。
对于centos7上新装包的ftp服务,默认没有此配置,可以不用经行操作,操作了也不会报错,不会改变配置文件。
# sed -i 's/userlist_deny=NO/userlist_deny=YES/g' /etc/vsftpd/vsftpd.conf   #仅供参考,可以不用操作

 

3. 添加用户

复制代码
useradd vsftpd01 -d /home/vsftpd -s /bin/false

mkdir /home/vsftpd/ftp{1..5} #ftp目录
chown -R vsftpd01.vsftpd01 /home/vsftpd/&&chmod -R 700 /home/vsftpd/&&chmod 600 /home/vsftpd/
复制代码

 

 

4. 修改pam文件

如果修改了 virtual_user_list.conf 文件,需要再次执行db_load命令,重新生成virtual_user_list.db文件

此文件保存虚拟用户(ftp登陆用户)名单

复制代码
cat > /etc/vsftpd/virtual_user_list.conf  <<EOF
ftp1
passwd_ftp1
ftp2
passwd_ftp2
ftp3
passwd_ftp3
ftp4
passwd_ftp4
ftp5
passwd_ftp5EOF
复制代码

 

 

复制代码
db_load -T -t hash -f /etc/vsftpd/virtual_user_list.conf /etc/vsftpd/virtual_user_list.db
chmod 600 /etc/vsftpd/virtual_user_list.db 


cat > /etc/pam.d/vsftpd << EOF auth sufficient /lib64/security/pam_userdb.so db=/etc/vsftpd/virtual_user_list account sufficient /lib64/security/pam_userdb.so db=/etc/vsftpd/virtual_user_list EOF
复制代码

5. 创建虚拟用户配置文件

配置说明:

包括ftp用户目录对应关系在这里
//设置FTP账号根目录,指定用户访问
local_root=/home/vsftpd/ftp/
//允许写入权限,包括修改
write_enable=YES
//允许匿名用户浏览,下载文件
anon_world_readable_only=NO
//允许匿名用户上传
anon_upload_enable=YES
//允许匿名用户上传/建立目录
anon_mkdir_write_enable=YES
//允许匿名用户具有建立目录,上传之外的权限,如重命名,删除
anon_other_write_enable=YES

mkdir /etc/vsftpd/virtual_user_cfg.d/

 

复制代码
echo '                     
for i in ftp{1..5}
do
cat > /etc/vsftpd/virtual_user_cfg.d/${i} << EOF
local_root=/home/vsftpd/${i}
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
EOF
done
' > mkuser.sh

sh mkuser.sh
复制代码
[root@localhost vsftpd]# ls virtual_user_cfg.d/
ftp1  ftp2  ftp3  ftp4  ftp5
[root@localhost vsftpd]# 

 

6. 调整主配文件

anonymous_enable=NO 禁止匿名用户登录
chroot_local_user=YES 禁止用户访问除主目录以外的目录
ascii_upload_enable=YES  设定支持ASCII模式的上传功能
ascii_download_enable=YES 设定支持ASCII模式的下载功能
guest_enable=YES 启动虚拟用户
guest_username=vsftpd01 虚拟用户使用的系统用户名
user_config_dir=/etc/vsftpd/virtual_user_cfg.d/ 虚拟用户使用的配置文件目录
allow_writeable_chroot=YES 最新版的vsftpd为了安全必须用户主目录没有写权限,才能登录,或者使用allow_writeable_chroot=YES

复制代码
sed -i 's/^anon/#anon/g' /etc/vsftpd/vsftpd.conf
sed -i -e 's/^ascii_/#ascii_/g' -e 's/^chroot_/#chroot_/g' /etc/vsftpd/vsftpd.conf


cat >> /etc/vsftpd/vsftpd.conf << EOF anonymous_enable=NO chroot_local_user=YES ascii_upload_enable=YES ascii_download_enable=YES guest_enable=YES guest_username=vsftpd01 user_config_dir=/etc/vsftpd/virtual_user_cfg.d/ allow_writeable_chroot=YES EOF

复制代码

如果重启服务后无法访问,试试添加chroot_list

复制代码

echo -e '\n'ftp{1..5} >> /etc/vsftpd/chroot_list;

 

cat >> /etc/vsftpd/vsftpd.conf << EOF
chroot_list_enable=YES
chroot_list_file=/etc/vsftpd/chroot_list
EOF

复制代码

 

7. 启服务

systemctl restart vsftpd

 8. 配置开机自启

 systemctl enable --now vsftpd

9. 如果无法访问

如果无法访问到ftp服务,可以查看端口通不通,不通则为防火墙限制

可以从客户机上用telnet访问ftp服务器的21端口

telnet 192.168.116.7 21

如果不通,先开通过防火墙

以firewalld为例

firewall-cmd --add-service=ftp --permanent
firewall-cmd --reload
[root@localhost ~]# firewall-cmd --list-service
dhcpv6-client ftp ssh

 

如果端口测试正常,应该可以正常访问到ftp服务,此时若账号登陆异常,先检查selinux状态

如果selinux开着,需保证ftpd_full_access为 on状态

如果有ftp_home_dir 的也需要设置为on

如果selinux已关闭,依然访问异常,基本可以断定是ftp用户配置的问题,请仔细核对ftp虚拟用户配置文件和对应的ftp登陆路径是否存在,权限是否充足

setsebool ftpd_full_access on

 

复制代码
[root@localhost ~]# getenforce
Enforcing
[root@localhost ~]# getsebool -a|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 --> off
复制代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/936803.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

芋道框架怎么样

最近工作中使用了一个java的后端框架叫做 芋道简单说一下我对他的理解和认识吧1.完美的前后端代码自动生成 2.完美的组件集成,包括工作流,ai,自动任务,文件管理器,mq等等缺点: 1.这个框架会挑选你的笔记本,如果…

神级掩护软件!老板路过我电脑在“系统更新中”

软件介绍 一键“假装电脑崩溃”神器来袭! 无论是蓝屏死机、FBI警告、系统更新卡死、还是无限重启,这款小巧的恶搞模拟器都能以假乱真地还原现场,让你轻松度过那些“不想被打扰”的时刻。 体积仅 7MB,却集成了多种经…

超真实“电脑崩溃模拟器”:蓝屏、重启、FBI警告一应俱全!

软件介绍 一键“假装电脑崩溃”神器来袭! 无论是蓝屏死机、FBI警告、系统更新卡死、还是无限重启,这款小巧的恶搞模拟器都能以假乱真地还原现场,让你轻松度过那些“不想被打扰”的时刻。 体积仅 7MB,却集成了多种经…

(20)ASP.NET Core2.2 EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性) - 指南

(20)ASP.NET Core2.2 EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性) - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !…

(在构造函数中)调用super(props)的目的是什么?

在 React 类组件 中,constructor 构造函数里调用 super(props) 是一个非常经典的机制, 一、基本背景 在 React 中,我们定义类组件时通常这样写: class MyComponent extends React.Component {constructor(props) {…

温故知新,机器人进化论,机器人分类与全球格局

机器人基本概念与范畴 “机器人”是一个比较宽泛的概念,不同文献和标准下的定义稍有差异。一般来说,机器人是能感知环境、作出决策或规划、并作用于环境的机械系统(带有驱动、传感、控制、算法等)的一类设备。 在工…

Zemax:初学者的混合模式 - 指南

Zemax:初学者的混合模式 - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco&qu…

【无标题】使用 Playwright 实现跨 Chromium、Firefox、WebKit 浏览器自动化管理

【无标题】使用 Playwright 实现跨 Chromium、Firefox、WebKit 浏览器自动化管理pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-…

西门子博图软件TIA V18使用PLCSIM Advanced V5.0进行仿真与其他程序进行通讯

由于标准版PLCSIM只是PLC内部通讯用,若要与外部进行通讯,需要安装Advanced版本,TIA V18的兼容advanced版本需要在V5.0以上,这里使用了V5.0版本。 PLCSIM Advanced V5.0安装过程中可能会有兼容性之类的报错 发生该…

MyEclipse 2017/2018 安装与破解 图文教程

SSM 框架-02-MyEclipse 2017/2018 安装与破解 现在在学J2EE,然后使用的工具就是 MyEclipse,现在就抛弃 Eclipse 了,我就不多说它俩的区别了,但是 MyEclipse 是收费的,下面介绍 MyEclipse 2017 安装与破解 一、下载…

面向对象初级

面向对象初级:1.面向对象三大特征:封装  继承   多态    self含义:  指向实例对象本身,让实例能够访问类中的属性和方法2.类和对象的创建:    类和对象的创建(登录注册功能) class User:def __in…

【文章目录】

文章目录 【STM32】 【STM32系列】STM32通用【STM32系列】基于HAL库的串口DMA空闲中断接收+串口DMA发送 【STM32系列】超好用的开源按键状态系统lwbtn,以及超详细的移植教程 【STM32系列】EXTI11触发三ADC同步(并非同…

Excel DDE 教學:即時資料交換的詳細指南 - 指南

Excel DDE 教學:即時資料交換的詳細指南 - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", …

子网掩码基础知识

子网掩码基础知识 子网掩码由连续的1和连续的0组成,1表示网络位,0表示主机位。 1. 基础概念IPv4地址:由32位二进制组成,通常表示为4个十进制数(如192.168.1.0)。 子网掩码:用于划分网络和主机部分。例如,255.2…

iOS 框架全解析,原生框架与跨平台框架对比、开发应用打包与 App Store 上架实战经验 - 指南

iOS 框架全解析,原生框架与跨平台框架对比、开发应用打包与 App Store 上架实战经验 - 指南pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !impor…

微信机器人框架

微信机器人框架、微信二次开发机器人接口开发、微信机器人制作教程API文档 接入指南、对接流程 1.申请api平台账号 2.开通接口权限 3.对接api 4.测试上线如何测试? 假如需要接收并处理微信消息,研发人员需掌握任意一…

AI元人文构想基础理论体系研究

AI元人文构想基础理论体系研究 ——2025.10.14修订版引言:AI元人文构想的理论溯源与概念界定1.1 理论背景与提出缘由 当前人工智能发展正面临根本性挑战:主流AI范式在有效处理人类价值的复杂性、模糊性和动态性方面存…

详细介绍:Go 语言中指针介绍

详细介绍:Go 语言中指针介绍pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco"…

实用指南:JavaWeb 课堂笔记 —— 24 AOP 面向切面编程

实用指南:JavaWeb 课堂笔记 —— 24 AOP 面向切面编程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas&q…

2025年7款与Jira数据同步的实用国产优秀项目管理软件对比

为什么我们需要这篇对比? 如果你是一位项目经理,或许经历过这些困扰:团队用惯了Jira,但因数据合规要求急需国产替代,却担心同步成本高、功能断层? 想找一款能与Jira无缝对接的工具,兼顾本地化服务与灵活扩展,却…