源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-12-07 10:27 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Shell脚本搭建FTP服务器(vsftpd)
各种知识点都写在注释里。 只需要 sudo $PATH/ftpsetup.sh即可,默认以test/test为用户名密码登录,登录后的根目录只读,子目录writable可写。 Ubuntu 13和Linux Mint 15上测试ok。
[url=https://help.ubuntu.com/community/vsftpd#The_workshop]https://help.ubuntu.com/community/vsftpd#The_workshop[/url] # 创建用户名和密码的数据库,以单数行为用户名,双数行为密码记录 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
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部