linux FTP文本传输
目录
一、文本传输协议
二、连接方式
三、程序安装
四、黑名单和白名单
五、实验
1.实验一:匿名用户下载与上传
2.实验二:关闭匿名用户登录,允许普通用户登录在家目录上传和下载
3.实验三:禁止用户切换目录,只能在家目录操作
4.实验四:黑名单限制test1登录
5.实验五:白名单限制
6.实验六:root登录
一、文本传输协议
ftp特点:1.网络控制文件的双向传输
2.是一个应用程序
3.有不同操作系统ftp
4.都遵守同一种协议
5.传输协议tcp
6.通信端口20 和21(20是建立数据连接,传输文件数据,21是控制连接,传输ftp控制命令)
二、连接方式
1.主动模式:服务器主动对客户端发起连接,客户端与服务器的21端口连接,需要传输数据时,客户端会选择一个未使用的端口,告知服务器通过此端口传输数据,服务器通过连接将连接请求发给客户端,确定建立连接。
2.被动模式:客户端主动对服务器发起连接,客户端与服务器的21端口连接,需要传输数据时,服务器现在在一个未使用的端口,告诉服务器通过此端口传输数据,客户端通过连接将连接请求发给客户端,确定建立连接。
主动模式和被动模式区别:
生产中一般采用被动模式,这样可以更好的跨过防火墙的限制。
红色时主动模式,蓝色时被动模式

三、程序安装
vsftpd安装

四、黑名单和白名单
黑名单:凡是在名单上都不可以登录
白名单:只有在名单上才可以登录(安全性较高)
最后权限文件:ftpusers,里面用户不可登录(系统用户)

五、实验
1.实验一:匿名用户下载与上传
默认备份文件
进入配置文件夹,备份一份vsftpd.conf


进入配置文件进行修改
允许匿名用户上传文件。默认已注释,需取消注释
允许匿名用户创建(上传)目录。默认已注释,需取消注释
允许删除、重命名、覆盖等操作。需添加

重启服务
关闭防火墙,关闭安全机制

增加匿名文件pub权限

增加一个文件便于上传和下载

下载txt

查看test.txt文件

上传text1.txt
先创建一个text1.txt文件


接收成功,查看文件

2.实验二:关闭匿名用户登录,允许普通用户登录在家目录上传和下载
设置用户密码

将文件权限设置为只能在宿主目录操作

可以看到
在其他目录是不能上传和下载,只有在/home/test1家目录里才可以操作

3.实验三:禁止用户切换目录,只能在家目录操作
将用户禁锢在家目录
允许写权限

重启服务

可以看到test1用户想切换到/opt目录无法切换
但是可以在家目录查看

4.实验四:黑名单限制test1登录
打开黑名单
vim /etc/vsftpd/vsftpd.conf

查看黑名单用户名

确定没有test1,说明test1可以登录

test1确实可以登录

5.实验五:白名单限制
vim /etc/vsftpd/vsftpd.conf

确定有test1,说明test1可以登录,没有test2不可登录

切换黑白名单要重启服务vsftp
可以看到test1可以登录,test2不可登录

6.root可以登录(默认不能登录)
进入ftbusers删除root,user_list里也加入root(现在是白名单)


可以看到可以登录

linux FTP文本传输的更多相关文章
- FTP文本传输协议
一.存储类型 存储类型分为三种: 直连式存储:Direct-Attached Storage,简称DAS 网络附加存储:Network-Attached Storage,简称NAS(存储和管理空间都在 ...
- linux之FTP服务搭建 ( ftp文件传输协议 VSFTPd虚拟用户)
FTP服务搭建 配置实验之前关闭防火墙 iptables -F iptables -X iptables -Z systemctl stop firewalld setenforce 0 1.ftp简 ...
- 详述Linux ftp命令的使用方法
转自:http://os.51cto.com/art/201003/186325.htm ftp服务器在网上较为常见,Linux ftp命令的功能是用命令的方式来控制在本地机和远程机之间传送文件,这里 ...
- Linux的文本处理工具浅谈-awk sed grep
Linux的文本处理工具浅谈 awk 老大 [功能说明] 用于文本处理的语言(取行,过滤),支持正则 NR代表行数,$n取某一列,$NF最后一列 NR==20,NR==30 从20行到30行 FS ...
- 【RL-TCPnet网络教程】第35章 FTP文件传输协议基础知识
第35章 FTP文件传输协议基础知识 本章节为大家讲解FTP(File Transfer Protocol,文件传输协议)的基础知识,方便后面章节的实战操作. (本章的知识点主要整理自网络) ...
- FTP文件传输服务
FTP文件传输服务 一 .FTP 连接及传输的模式 l 控制连接:TCP21,用于发送FTP命令信息. l 数据连接:TCP 20, 用于上传下载数据. · 数据连接建立的类型: ·主动模式: 服 ...
- Linux ftp 命令
一.ftp的get命令和mget命令有何不同? get一次只下载一个文件:mget一次可以下载多个文件,而且支持通配符,需要注意的是在mget的时侯,需要对每一个文件都选择y/n,如果想不交互的下载全 ...
- Linux ftp命令的使用方法 -- 转
http://jingyan.baidu.com/article/066074d68b6a7ac3c21cb038.html FTP(File Transfer Protocol, FTP)是TCP/ ...
- FTP(文件传输协议)工作原理
目前在网络上,如果你想把文件和其他人共享.最方便的办法莫过于将文件放FTP服务器上,然后其他人通过FTP客户端程序来下载所需要的文件. 1.FTP架构 如同其他的很多通讯协议,FTP通讯协议也采用客户 ...
- Linux ftp Command
一.ftp的get命令和mget命令有何不同? get一次只下载一个文件:mget一次可以下载多个文件,而且支持通配符,需要注意的是在mget的时侯,需要对每一个文件都选择y/n,如果想不交互的下载全 ...
随机推荐
- Python学习笔记--序列+集合+字典
序列 切片:从一个序列中,取出一个子序列 注意: 案例: 实现: 集合 无序性.唯一性 添加新元素: .add 移除元素: .remove 随机取出某个元素: 清空集合: .clear 取两个集合的差 ...
- OVS学习博客推荐
博客学习 大致看一遍 openvswitch处理upcall过程分析 upcall-cost分析 连接跟踪(conntrack):原理.应用及 Linux 内核实现 ovs upcall处理流程 Li ...
- Linux & 标准C语言学习 <DAY7>
一.windows下获取方向键: 1.导入#include <conio.h> 2.通过getch()获取键盘上的键值 上:72 下:80 左:75 ...
- pyinstall打包工具使用简介
使用pyinstall进行多个文件打包,直接打包主入口文件即可 pyinstaller MainUI.py -F -n ServerMonitorv200 -i PIC.ico -w 此处MainUI ...
- 声网把七年无全网事故的实时传输网络SD-RTN全面开放了——这就是FPA!
8 月 19 日,声网Agora 举办线上产品发布会,正式发布了"全链路加速 FPA(Full-Path Accelerator)".全链路加速 FPA 基于声网的软件定义实时网络 ...
- springboot 接入 ChatGPT
项目地址 https://gitee.com/Kindear/lucy-chat 介绍 lucy-chat是接入OpenAI-ChatGPT大模型人工智能的Java解决方案,大模型人工智能的发展是不可 ...
- LevelDb-基本数据结构
目录 Slice Arena skip list 跳表本质 时空复杂度 插入,删除数据(如何维护索引) 极端情况分析:不维护索引 极端情况分析:每次插入都维护 插入效率和查找效率取舍 删除 对比红黑树 ...
- 简单入门echart方法
图表用echart, 然后前端的 HTML 跟 nodejs , nodejs 去调用 后端PHP的接口 链接:https://www.jianshu.com/p/1f2c37c5c02f 官网:h ...
- 全网最详细中英文ChatGPT-GPT-4示例文档-智能编写Python注释文档字符串从0到1快速入门——官网推荐的48种最佳应用场景(附python/node.js/curl命令源代码,小白也能学)
目录 Introduce 简介 setting 设置 Prompt 提示 Sample response 回复样本 API request 接口请求 python接口请求示例 node.js接口请求示 ...
- [IDE]IntelliJ IDEA 不能识别 Java 项目 [转]
本文转载自 IntelliJ IDEA 不能识别 Java 项目 - 博客园/SmartJuneThx 解决方法 非maven项目 在 src 目录上点右键,选择 Mark Directory As ...