(2)配置 ftp 虚拟用户认证模式,虚拟用户 ftp1 和 ftp2 映射为 ftp,ftp1 登录 ftp 后的目录为/var/ftp/vdir/ftp1,可以上传下载, 禁止上传后缀名为 .docx 的文件;ftp2 登录 ftp 后的目录为 /var/ftp/vdir/ftp2,仅有下载权限

时间: 2023-11-26 21:04:42 浏览: 44
要配置 FTP 虚拟用户认证模式,并映射虚拟用户 `ftp1` 和 `ftp2` 为 `ftp` 用户,同时设置不同的目录和权限,可以按照以下步骤进行操作: 1. 安装 vsftpd 软件包(如果尚未安装): ``` sudo apt update sudo apt install vsftpd ``` 2. 创建虚拟用户数据库文件: ``` sudo touch /etc/vsftpd/virtual_users.db sudo db_load -T -t hash -f /etc/vsftpd/virtual_users.txt /etc/vsftpd/virtual_users.db ``` 3. 编辑虚拟用户配置文件: ``` sudo nano /etc/pam.d/vsftpd_virtual ``` 4. 在文件中添加以下内容: ``` auth required pam_userdb.so db=/etc/vsftpd/virtual_users account required pam_userdb.so db=/etc/vsftpd/virtual_users ``` 5. 保存并退出文件。 6. 创建虚拟用户配置文件: ``` sudo nano /etc/vsftpd/virtual_users.txt ``` 7. 在文件中添加以下内容,将 `ftp1` 和 `ftp2` 映射为 `ftp` 用户,并设置不同的目录和权限: ``` ftp1 ftp /var/ftp/vdir/ftp1 ftp2 ftp /var/ftp/vdir/ftp2 ``` 8. 保存并退出文件。 9. 修改 vsftpd 配置文件: ``` sudo nano /etc/vsftpd.conf ``` 10. 确保以下配置项的值如下: ``` listen=YES anonymous_enable=NO local_enable=YES write_enable=YES local_umask=022 dirmessage_enable=YES use_localtime=YES xferlog_enable=YES connect_from_port_20=YES chroot_local_user=YES secure_chroot_dir=/var/run/vsftpd/empty pam_service_name=vsftpd_virtual guest_enable=YES guest_username=ftp virtual_use_local_privs=YES user_sub_token=$USER local_root=/var/ftp/vdir/$USER allow_writeable_chroot=YES pasv_enable=YES pasv_min_port=30000 pasv_max_port=31000 ``` 11. 保存并退出文件。 12. 重启 vsftpd 服务: ``` sudo systemctl restart vsftpd ``` 现在,你可以使用虚拟用户 `ftp1` 和 `ftp2` 连接到 FTP 服务器。`ftp1` 用户能够上传和下载文件,但禁止上传后缀名为 `.docx` 的文件。`ftp2` 用户仅有下载权限。他们分别登录后的目录为 `/var/ftp/vdir/ftp1` 和 `/var/ftp/vdir/ftp2`。 请注意,上述步骤假设你使用的是 Ubuntu 或基于 Ubuntu 的 Linux 发行版。如果你使用其他发行版,请根据需要调整命令和文件路径。

相关推荐

最新推荐

recommend-type

Filezilla server配置FTP服务器中的各种问题与解决方法

主要介绍了Filezilla server配置FTP服务器中的各种问题与解决方法,需要的朋友可以参考下
recommend-type

对服务器的ftp端口进行修改.docx

 1、完成一个FTP的传输过程不仅仅只需要21一个端口,而是2个端口,21端口只是一个命令端口,其实另外还有一个数据端口,我想这就是有些朋友在内网架设FTP并且在网关上做了21端口的映射之后外网还是不能访问的原因吧...
recommend-type

用Java实现FTP批量大文件上传下载

文章在比较了一系列FTP客户库的基础上,就其中一个比较通用且功能较强的j-ftp类库,对一些比较常见的功能如进度条、断点续传、内外网的映射、在Applet中回调JavaScript函数等问题进行详细的阐述及代码实现,希望通过...
recommend-type

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a

pre_o_1csdn63m9a1bs0e1rr51niuu33e.a
recommend-type

matlab建立计算力学课程的笔记和文件.zip

matlab建立计算力学课程的笔记和文件.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。