在centos7安装ftp服务

  1. yum install -y vsftpd

启动服务

  1. systemctl start vsftpd

自启动

  1. systemctl enable vsftpd

查看端口

注意关闭SELinux和本地防火墙,否则不能正常操作

重要文件

/var/ftp/pub/  默认共享目录

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

/etc/vsftpd/user_list  黑名单,可修改成白名单

/etc/vsftpd/ftpusers  黑名单

FTP相关用户

匿名用户

  1. anonymousftp

本地用户

  1. Linux系统用户

虚拟用户

  1. 管理员自定义用户

配置文件/etc/vsftpd/vsftpd.conf

  1. anonymous_enable=YES ### 允许匿名登录,建议关闭
  2. local_enable=YES ### 允许本地用户登录
  3. write_enable=YES ### 允许对文件系统做改动的 FTP 命令
  4. local_umask= ### 本地用户创建文件所用的 umask 值
  5. dirmessage_enable=YES ### 当用户首次进入一个新目录时显示一个消息
  6. xferlog_enable=YES ### 用于记录上传、下载细节的日志文件
  7. connect_from_port_20=YES ### 主动模式数据传输接口
  8. xferlog_std_format=YES ### 使用标准的ftp日志格式
  9. listen=NO ### 不要让 vsftpd 运行在独立模式
  10. listen_ipv6=YES ### vsftpd 将监听 IPv6 而不是 IPv4
  11. pam_service_name=vsftpd ### vsftpd 使用的 PAM 服务名
  12. userlist_enable=YES ### 用户登入限制
  13. tcp_wrappers=YES ### 使用 tcp wrappers

匿名用户登入

在默认情况下,ftp可以用匿名用户登入,登入的目录为/var/ftp/

用户名为anonymous或ftp,密码为空,建议关闭

默认情况下,只能在对应的目录下进行下载文件,不能上传文件

可以修改对应的配置文件,允许匿名用户进行文件上传和建立目录的权限

配置文件/etc/vsftpd/vsftpd.conf中将以下两行注释去掉即可

  1. anon_upload_enable=YES #允许上传文件
  2. anon_mkdir_write_enable=YES #允许建立目录

重启服务,同时还需要让ftp作为/var/ftp/pub的所有者

  1. chown ftp pub/

重新用匿名用户登入ftp就可以在pub/上传文件和建立目录

系统用户登入

采用Linux的系统用户作为ftp服务的用户进行登入,但是因为ftp是明文传递,如果被人截获数据包,就相当于获得Linux的用户和密码,因此建议关闭

默认情况下,采用系统用户登入,可以进行上传下载,目录为用户的家目录

可以修改配置文件更换系统用户的登入位置,在/etc/vsftpd/vsftpd.conf添加

  1. local_root=/tmp/test_home/

然后建立对应的目录 mkdir /tmp/test_home,重启服务

再次登入ftp,目录为/tmp/test_home,其他Linux用户登入ftp服务也是在这个目录(注意系统的目录权限)

但是用系统用户登入ftp存在一个缺陷,即可以切换到根目录,可以窃取其他目录的信息,所以我们需要把系统用户禁锢在家目录下

进入配置文件,把这句话前面的注释去掉,然后重启服务,即把所有的系统用户限制在家目录下

  1. chroot_local_user=YES

注意一个特别配置,如果把这三句都去掉注释,同时在/etc/vsftpd/建立一个chroot_list,里面的内容为系统用户,那么写在这里的系统用户则可以访问任何目录

  1. chroot_local_user=YES
  2. chroot_list_enable=YES
  3. chroot_list_file=/etc/vsftpd/chroot_list

假如我们在/etc/vsftpd/chroot_list添加一个系统用户test2,那么这个系统用户登入ftp服务器,则可以访问根目录,也可以访问其他目录

黑名单与白名单

/etc/vsftpd/ftpusers和 /etc/vsftpd/user_list默认情况下都是黑名单,但是/etc/vsftpd/user_list可以通过配置文件修改成白名单

在/etc/vsftpd/vsftpd.conf配置文件中

  1. userlist_enable=YES #在这句下面添加以下两句,将user_list反转成白名单
  2. userlist_deny=NO
  3. userlist_file=/etc/vsftpd/user_list

注意黑名单的权限比白名单大,即同时存在与黑名单和白名单,依旧被禁用

虚拟用户登入

比较安全和常见的登入方式为虚拟用户登入,即只能登入ftp服务器

1、添加一个虚拟用户口令文件

  1. vim /etc/vsftpd/vuser.txt

在里面输入虚拟用户和密码

  1. vtest #账户
  2. test #密码
  3. vtest2 #账户
  4. test2 #密码

2、生成认证文件

  1. db_load -T -t hash -f /etc/vsftpd/vuser.txt /etc/vsftpd/vuser.db

如果没有安装口令认证文件先安装

  1. yum -y install db4-utils

3、编辑pam认证文件

进入 /etc/pam.d/vsftpd,注释掉原来的内容,因为系统登入依赖这个文件
 在后面添加两行

  1. auth required /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser
  2. account required /lib64/security/pam_userdb.so db=/etc/vsftpd/vuser

4、建立本地映射用户

  1. useradd -d /home/vftproot -s /sbin/nologin vuser
  2. chmod /home/vftproot

5、修改配置文件

在/etc/vsftpd/vsftpd.conf下面添加

  1. guest_enable=YES
  2. guest_username=vuser
    user_config_dir=/etc/vsftpd/vuser_conf

然后重启服务,就可以进行虚拟用户登入,记得删除原来的vuser.txt文件

虚拟用户进行目录分配

  1. mkdir /etc/vsftpd/vuser_conf

在这个目录下创建文件,文件名为虚拟用户名,在里面指定权限和目录,没有设置的虚拟用户则根据主配置文件

  1. vim /etc/vsftpd/vuser_conf/vtest2
  1. anon_upload_enable=YES
  2. anon_mkdir_write_enable=YES
  3. local_root=/tmp/vtest2
  1. mkdir /tmp/vtest2
    chown vuser vtest2/

并在配置文件中添加

  1. allow_writeable_chroot=YES

重启服务,再次登入,可以正常使用

FTP安装及配置的更多相关文章

  1. [Windows Server 2003] IIS自带FTP安装及配置方法

    ★ 欢迎来到[护卫神·V课堂],网站地址:http://v.huweishen.com★ 护卫神·V课堂 是护卫神旗下专业提供服务器教学视频的网站,每周更新视频.★ 本节我们将带领大家:IIS6.0自 ...

  2. Linux下FTP安装与配置

    第一部分 .note-content {font-family: 'Helvetica Neue', Arial, 'Hiragino Sans GB', STHeiti, 'Microsoft Ya ...

  3. [转]CentOS 5.5下FTP安装及配置

    一.FTP的安装 1.检测是否安装了FTP : [root@localhost ~]# rpm -q vsftpd vsftpd-2.0.5-16.el5_5.1 否则显示:[root@localho ...

  4. CentOS7 FTP安装与配置

    1.FTP的安装 #安装yum install -y vsftpd #设置开机启动systemctl enable vsftpd.service #启动systemctl start vsftpd.s ...

  5. IIS6自带FTP安装及配置方法

    参考:http://v.huweishen.com/video/9.html ·IIS自带的FTP服务是最安全的,不会像Serv-U那样存在各种漏洞:但其配置过程也比较复杂. ·本节将以虚拟目录方式, ...

  6. 从零开始搭建系统1.7——FTP安装及配置

    1.安装vsftp软件包 [root@localhost usr]# yum install -y vsftpd 2.先备份vsftpd的默认配置文件 [root@localhost usr]# cd ...

  7. centos 6.4 FTP安装和配置

    链接地址:http://blog.csdn.net/wind520/article/details/38019647 1: 安装 检查是否安装 [root@localhost ~]# rpm -qa ...

  8. linux ftp安装和配置

    1. 启动VSFTP服务器 A:cenos下运行:yum  install  vsftpd B. 登录Linux主机后,运行命令:"service vsftpd start"C. ...

  9. Linux 安装及配置 Nginx + ftp 服务器

    Nginx 安装及配置 一.Nginx 简介: Nginx("engine x") 是一款是由俄罗斯的程序设计师 Igor Sysoev 所开发高性能的 Web和 反向代理服务器, ...

随机推荐

  1. python学习-class封装

    # 封装 类=属性+行为 抽像 -class StudentV2: # 类属性 所有的实例可以共享 .不属于任何实例的特性. is_people = True # 类方法 1.装饰器.2.参数是cls ...

  2. 《MySQL数据库》MySQL数据库安装(linux)

    1.  下载安装包: 百度网盘:链接: https://pan.baidu.com/s/1toGl8O9gMBpDWn0mHWwFyg 提取码: i51g 官网下载:https://dev.mysql ...

  3. 织女星开发板使用RISC-V核驱动GPIO

    前言 织女星开发板是OPEN-ISA社区为中国大陆地区定制的一款体积小.功耗超低和功能丰富的 RISC-V评估开发板,基于NXP半导体四核异构RV32M1主控芯片. 两个RISC-V核:RI5CY + ...

  4. spring源码学习(三)--spring循环引用源码学习

    在spring中,是支持单实例bean的循环引用(循环依赖)的,循环依赖,简单而言,就是A类中注入了B类,B类中注入了A类,首先贴出我的代码示例 @Component public class Add ...

  5. Python工作好找吗?没有工作经验和学历怎么找?【就业必学】

    大家都知道,随着人工智能时代的到来,Python的需求也变的越来越大了.从目前各大IT招聘网上显示招聘需求是非常大,而且薪资基本都在10k起,高的可达40-50k,当然这个要求很高,看下普遍的吧: 一 ...

  6. C#中提示:当前上下文中不存在名称“ConfigurationManager”

    场景 想要在程序中获取App.config中设置的内容. 想要通过 ConfigurationManager.AppSettings[key]; 来进行获取,已经添加 using System.Con ...

  7. 阿里云esc 安装 mysql8.0

    打开 连接工具,我用的是 MobaXterm_Personal_12.1 (官网下载地址:https://moba.en.softonic.com/) 连接到 ecs,然后移除 默认的 mariadb ...

  8. PHP中使用date获取上月最后一天出现的问题

    上次做项目时,发现一个问题,这里记录一下: 问题: 在使用date函数获取上一个月最后一天或下个月最后一天时,如果当前日期是31号,获取的数据有问题. // 2019-12-01 正确应该是 2019 ...

  9. LinuxProbe小结

    1.修改主机名: /etc/hostname 2.配置 yum 软件仓库: (1)进入到 /etc/yum.repos.d/目录下,创建一个linuxprobe.repo的新文件(文件名称任意,结尾必 ...

  10. Jenkins使用SSH构建Go项目并执行

    目录 下载插件 配置要部署的服务器 构建项目 Jenkinx可以帮助我们通过SSH插件,将项目直接部署到指定的服务器. 下载插件 (1)点击左侧的"系统管理"菜单 ,然后点击 (2 ...