当前位置: 首页 > 编程笔记 >

Shell脚本搭建FTP服务器(vsftpd)

胡志
2023-03-14
本文向大家介绍Shell脚本搭建FTP服务器(vsftpd),包括了Shell脚本搭建FTP服务器(vsftpd)的使用技巧和注意事项,需要的朋友参考一下

各种知识点都写在注释里。

只需要 sudo $PATH/ftpsetup.sh即可,默认以test/test为用户名密码登录,登录后的根目录只读,子目录writable可写。

Ubuntu 13和Linux Mint 15上测试ok。


#!/bin/bash

# by liuhx 2013-Nov-04.

# 设置ftp环境的脚本。ftp的根目录为只读,其下的writable目录为可写

# 可自定义以下四项 # ftp用户名 userName="test" # ftp密码 password="test" # ftp根目录,末尾不要加/ ftp_dir="$HOME/ftp" # 可写目录的目录名 writable="writable"

# 如果没有加sudo,提示错误并退出 if [ "x$(id -u)" != x0 ]; then    echo "Error: please run this script with 'sudo'."    exit 1 fi

# 核心工具,vsftpd。 -y是对所有提示都回答yes sudo apt-get -y install vsftpd # db-util是用来生成用户列表数据库的工具 sudo apt-get -y install db-util

# 以下步骤参考https://help.ubuntu.com/community/vsftpd#The_workshop # 创建用户名和密码的数据库,以单数行为用户名,双数行为密码记录 cd /tmp printf "$userName\n$password\n" > vusers.txt db_load -T -t hash -f vusers.txt vsftpd-virtual-user.db sudo cp -f vsftpd-virtual-user.db /etc/ cd /etc chmod 600 vsftpd-virtual-user.db if [ ! -e vsftpd.conf.old ]; then  sudo cp -f vsftpd.conf vsftpd.conf.old fi

# 创建PAM file。bash的here-document,直接输出这些内容覆盖原文件 (sudo cat <<EOF auth       required     pam_userdb.so db=/etc/vsftpd-virtual-user account    required     pam_userdb.so db=/etc/vsftpd-virtual-user session    required     pam_loginuid.so EOF ) > pam.d/vsftpd.virtual

# 获取当前的用户名,不能用whoami或$LOGNAME,否则得到的是root owner=`who am i| awk '{print $1}'`

# 创建vsftpd的配置文件。 (sudo cat <<EOF listen=YES anonymous_enable=NO local_enable=YES virtual_use_local_privs=YES write_enable=YES local_umask=000 dirmessage_enable=YES use_localtime=YES xferlog_enable=YES connect_from_port_20=YES chroot_local_user=YES hide_ids=YES secure_chroot_dir=/var/run/vsftpd/empty pam_service_name=vsftpd.virtual guest_enable=YES user_sub_token=$USER rsa_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem rsa_private_key_file=/etc/ssl/private/ssl-cert-snakeoil.key EOF ) > vsftpd.conf sudo echo "local_root=$ftp_dir" >> vsftpd.conf # 虚拟用户需要映射为本地用户,设为自己,避免权限问题,但同时也令自己对ftp根目录不可写 sudo echo "guest_username=$owner" >> vsftpd.conf

# 设置了每个虚拟用户只可以浏览其根及子目录(否则可访问磁盘根目录), # 这样会被要求根目录不可写,所以创建一个writable的子目录 mkdir "$ftp_dir" mkdir "$ftp_dir/$writable" sudo chmod a-w "$ftp_dir" sudo chown -R $owner:$owner $ftp_dir

sudo /etc/init.d/vsftpd restart

 类似资料:
  • 本文向大家介绍Centos7搭建FTP服务器,包括了Centos7搭建FTP服务器的使用技巧和注意事项,需要的朋友参考一下 从网上搜索了好多搭建Centos7搭建服务器的教程都没有成功唯独这个,利用Windows资源管理器连接测试成功。 一、通过yum安装vsftpd yum install -y vsftpd 二、修改vsftpd的配置文件 vi /etc/vsftpd/vsftpd.conf

  • 本文向大家介绍FTP服务器搭建之本地用户篇,包括了FTP服务器搭建之本地用户篇的使用技巧和注意事项,需要的朋友参考一下 Vsftpd3.0--FTP服务器搭建之本地用户篇,具体内容如下 FTP服务在工作中是经用到的一种工具,可以实现上传下载等功能。那么今天我们来聊一聊FTP服务器使用本地用户登录的实现模式。 既然是本地用户,就少不了要创建本地用户,下面我们创建2个用户: 第一步:创建用户 第一次创

  • 本文向大家介绍CentOS6.9中搭建FTP服务器的方法,包括了CentOS6.9中搭建FTP服务器的方法的使用技巧和注意事项,需要的朋友参考一下 1 基本环境 2 ftp工作模式 2.1 ftp通道 ftp工作会启动两个通道: 控制通道,数据通道 在ftp协议中,控制连接均是由客户端发起的,而数据连接有两种模式:port模式(主动模式)和pasv(被动模式) 2.2 port模式 在客户端需要接

  • 本文向大家介绍Python搭建FTP服务器的方法示例,包括了Python搭建FTP服务器的方法示例的使用技巧和注意事项,需要的朋友参考一下 Python版本 3.6.2 使用的ftp包:pyftpdlib    pip install pyftpdlib就可以下载安装了 FTP协议下载上传文件在文件过大的情况下会比HTTP更具有优势,更为方便的实现断点上传和进度监控,下面是官方文档中的 基本方法

  • 本文向大家介绍Android 快速搭建FTP服务器的方法,包括了Android 快速搭建FTP服务器的方法的使用技巧和注意事项,需要的朋友参考一下 一、概述   打开你的手机,找到文件管理->分类->远程管理,点击启动服务,这样大家可以在局域网内使用电脑访问你手机上的文件了,当然你也可以设置账号和密码,防止“小人”共享你手机上的资源-.-,那如果自己动手,该如何实现这个小功能呢? 二、实现 1、导

  • 本文向大家介绍Shell脚本实现上传zip压缩文件到FTP服务器,包括了Shell脚本实现上传zip压缩文件到FTP服务器的使用技巧和注意事项,需要的朋友参考一下