您好,登录后才能下订单哦!
文章主要讲了CentOS8如何利用vsftpd搭建一个FTP服务器,然后进行简单的匿名上传/下载与用户上传/下载测试,还有使用了wget测试.
yum install -y vsftpd
service httpd start
可以用
systemctl list-unit-files | grep vsftpd
查看是否开机启动.显示disabled.
通过
chkconfig vsftpd on
开启自启,再次执行systemctl,可以看到变成了enabled.
sudo vim /etc/vsftpd/vsftpd.conf
首先修改
为YES.
再添加一行anon_upload_enable=YES
第一行的意思是允许匿名登录,第二行的意思是允许匿名上传.
重启服务.
service vsftpd restart
cd /var/ftp/pub
sudo vim test
ifconfig获取内网ip,在浏览器中输入ftp://ip.
可以看到有一个pub文件夹,里面有刚才新建的test文件.
右键保存即可下载文件.
下载完成.
去终端看看.
输入
ftp://username@ip
再输入用户密码.
默认访问的是用户根目录下的文件,这里显示出来了.
下载的话同上,右键选择即可.
首先安装ftp:
sudo yum install ftp
ftp ip
这里用户名选择ftp,密码为空,表示匿名登录.ftp为默认的匿名登录用户名,至于密码,可以在/etc/vsftpd/vsftpd.conf中设置一个
no_anon_password=YES
这样匿名用户可以不用密码登录.
直接使用put命令,后面接上文件,这里的upload.txt是执行ftp之前的所在文件夹下的upload.txt
这里提示不能创建文件,是权限的原因,要确保/var/ftp/pub对"other"用户有写权限.
默认的/var/ftp/pub的权限是644,修改成647.
sudo chmod 647 /var/ftp/pub
同时修改上传文件的权限,允许other用户可读.
sudo chmod 644 /root/upload.txt
如果不行,使用selinux设置.
getsebool -a | grep ftp
把ftpd_full_access开启:
setsebool ftpd_full_access on
再进入upload.txt所在的文件夹,执行ftp,再次put.
成功!
直接get文件即可,由于上面已经设置好了权限,所以不会出现问题.
若出现权限问题可从三方面入手:
执行ftp时用对应用户名与密码登录.
默认进入了用户根目录.
直接put即可.
若出现权限问题参照上面7.2.1.2的那三条方法.
随便在用户根目录新建一个文件,这里是kr.
直接get即可.
wget用来下载文件,初始下载的目录与ftp登录时的目录一致,比如匿名登录ftp,登录的是/var/ftp目录,则wget会从这个/var/ftp目录下载文件,下载到执行wget命令所在的目录.使用用户"kr"登录ftp,则登录的是/home/kr目录,wget会从/home/kr下载文件.
注意,请确保被下载文件对other用户有可读权限.
sudo chmod o+w xxxxxx
然后使用wget
wget ftp://ip/pub/xxxx
使用--ftp-user,--ftp-password指定用户名与密码,其余同上.
wget ftp://ip/xxx --ftp-user=xxxx --ftp-password=xxxx
成功.
呃....简单来说,就是先安装好ftp与vsftpd,然后修改/etc/vsftpd/vsftpd.conf添加相应权限,对于不能上传与下载的原因,基本上都是权限的问题,主要就是三方面:
解决权限问题后,基本就可以通过ftp或wget顺利地使用这个ftp服务器上传/下载文件了.
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。