树莓派搭建ftp服务器配置本地用户访问

树莓派搭建ftp服务器配置本地用户访问

本文关键字
树莓派,raspberry,debian,ftp,vsftpd,本地用户

安装并配置ftp服务器-vsftpd

  1. 安装ftp服务器
sudo apt-get install vsftpd
  1. 启动ftp服务
sudo service vsftpd start
  1. 修改默认配置
sudo nano /etc/vsftpd.conf

寻找并打开如下注释:

# 不允许匿名访问
anonymous_enable=NO
# 可以写入
write_enable=YES
# 设置上传文件掩码
local_umask=022
# 使用utf-8字符集
utf8_filesystem=YES

不允许用户浏览自己根目录以外目录需额外做如下修改:

#取消注释并将其改为NO
chroot_local_user=NO
#设置通过读取文件确定哪些用户不允许离开自己的用户目录
chroot_list_enable=YES

存盘退出nano:
ctrl+o
ctrl+x
注意,需指定限制用户列表
设置了chroot_list_enable=YES后,必须建立列表文件,
否则客户端连接失败
建立/etc/vsftpd.chroot_list文件,将不允许离开自己根目录的用户加入到该文件中,一行一个用户名比如:

sudo nano /etc/vsftpd.chroot_list
#在文件中添加限制的用户名
student
test
  1. 重启ftp服务:
sudo service vsftpd restart
  1. 测试ftp服务
    如果暂时没有安装ftp客户端可以在windows下通以下方式访问
    在资源管理器地址栏中输入:
ftp://ip地址
  1. 此时树莓派默认用户:pi基本上可以访问ftp

ftp客户端安装

  1. 推荐使用:fileZilla
    下载连接:[https://filezilla-project.org/download.php]
    2.连接到树莓派ftp服务器:
    用户名:pi 默认密码:raspberry
    ftp根目录:/home/pi
    连接端口:21
    如果查看到的文件夹出现乱码,可以修改fileZilla客户端配置,在站点管理器-我的站点-新建站点
    -字符集-强制使用utf-8
  2. 其他ftp客户端
    Xftp:[https://www.netsarang.com/download/down_xfp.html]
    可选择home/school版本下载

添加本地用户访问

  1. 添加本地用户
    sudo adduser student
    默认建立同名home目录
  2. 在客户端使用新建立用户登陆ftp服务器
    新建立用户如果连接时报530错误,可参考如下解决方案:
    除了前面的设置外,新建用户仍然无法访问ftp服务
    在树莓派(debian)系统中客户端连接时会报530错误:
530 Login incorrect.

此时需要编辑/etc/pam.d/vsftpd文件
将最后一行注释掉,不使用pam的默认授权:

auth required pam_shells.so
  1. 限制新建用户不能离开自己的home目录,需参考前面操作将其添加到限制列表中:
    即编辑vsftpd.chroot_list文件将用户名填到该文件中

使用软链接存储ftp文件

由于树莓派sd卡容量有限,做ftp需要额外的硬盘空间,在使用树莓派3b+版本时,支持自动挂载usb设备
只需到media/pi目录下查看挂载的设备

  1. 在挂载设备上建立文件夹并授权
    在该设备上建立ftp存储文件夹,并将文件夹所有权赋给相应使用ftp的用户
    参考命令:
chown -R test your_usb_dir
# -R 递归操作 test为用户名 your_usb_dir为设备上用于ftp存储的目录名
  1. 在用户home目录下建立软链接文件夹,并进行挂载
mount --bind   /media/pi/04b0b893-7bca-b54f-b7cb-0e7d051803a9/ftp/student     /home/student/ftp
#将左侧文件夹挂载到右侧文件夹,文件实际存储在左侧文件夹
# 卸载命令为umount
  1. 如无法向usb设备上存储文件,请检查usb设备相应文件夹的存取权限
  2. 采用第2步方式挂载当系统重新启动后目录会丢失,这时最好采取开机挂载目录方案,修改/etc/rc.local文件添加自动执行命令
    sudo nano /etc/rc.local
    在exit 0前面添加如下内容
sleep 20s && /bin/mount --bind /media/pi/04b0b893-7bca-b54f-b7cb-0e7d051803a9/ftp/student     /home/student/ftp

命令说明:
sleep 20s表示等待20秒,&& 表示后台运行
这样做的原因是usb设备的挂载也需要时间,等usb设备挂载完毕后再挂载ftp目录,否则在挂载时找不到usb设备.
如果挂载不成功,可以在命令行输入:

systemctl status rc-local.service

查看出错信息

  1. 其他挂载方式:
    很多资料都是使用fstab去挂载,但是在树莓派下一旦出错,系统无法启动,此时没有外接显示器连ssh也无法使用,如果采用rc.local的方式,即使出错系统还是能够启动的。方便查找原因
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容