文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2022-06-04 21:47

关注

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

只需要 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 "$userNamen$passwordn" > 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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-服务器
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯