linux下vsftpd的安装及配置使用详细步骤(推荐)
vsftpd是“verysecureFTPdaemon”的缩写,安全性是它的一个最大的特点。
vsftpd是一个UNIX类操作系统上运行的服务器的名字,它可以运行在诸如Linux、BSD、Solaris、HP-UNIX等系统上面,是一个完全免费的、开放源代码的ftp服务器软件,支持很多其他的FTP服务器所不支持的特征。
比如:非常高的安全性需求、带宽限制、良好的可伸缩性、可创建虚拟用户、支持IPv6、速率高等。
vsftpd是一款在Linux发行版中最受推崇的FTP服务器程序。特点是小巧轻快,安全易用。
1.1 安装
命令:
yuminstallvsftpd-y
配置Vsftpd
安装完之后我们要对它进行配置,才能正常使用。
编辑vsftpd的配置文件
vi/etc/vsftpd/vsftpd.conf
在配置文件中找到“anonymous_enable=YES”,将"YES"改为"No",将匿名登录禁用。
添加开机自动启动,
chkconfigvsftpdon
不确定是否已经加入了开机启动项可以运行chkconfig–list进行查看
1.2 创建用户
命令:useraddftpuser
指定密码:passwdftpuser
此用户就是用来登录ftp服务器用的。
这样一个用户建完,可以用这个登录,记得用普通登录不要用匿名了。登录后默认的路径为/home/ftpuser.
----------------------------------------------------------------------------------------------------------------------------------
设置FTP用户的账号,例如账号为“ftpuser1”,目录为/home/ftpuser1,且设置不允许通过ssh登录。
useradd-d/home/ftpuser-s/sbin/nologinftpuser
设置账号对应的密码,例如密码为“ftpuser”
passwdftpuser
1.3 开启selinux权限
VSFTPD是一个FTP服务器程序,然后SELinux是CentOS的防火墙组件。由于vsftpd默认被SELinux拦截,所以会遇到的FTP以下的问题:
1.226Transferdone(butfailedtoopendirectory).(传输完成,但是打开路径失败)
2.550Failedtochangedirectory(更改路径失败)
3.
553Couldnotcreatefile.
4.
或者干脆在发送了LIST命令以后,服务器没响应,超时断开。
遇到这样的问题,通常是vsftpd没有足够的权限,很有可能是被SELinux阻止了。
查看命令:getsebool-a|grepftp
getsebool-a|grepftpd #以下是显示出来的权限,off是关闭权限,on是打开权限 allow_ftpd_anon_write-->off allow_ftpd_full_access-->off allow_ftpd_use_cifs-->off allow_ftpd_use_nfs-->off ftpd_connect_db-->off ftpd_use_passive_mode-->off ftp_home_dir-->off
其中,ftp_home_dir和allow_ftpd_full_access必须为on才能使vsftpd具有访问ftp根目录,以及文件传输等权限。
设置命令:setsebool-pxxxxxxon
[root@bogon~]#setsebool-Pallow_ftpd_full_accesson [root@bogon~]#setsebool-Pftp_home_diron
1.4 设置或关闭防火墙
因为ftp默认的端口为21,而centos默认是没有开启的,所以要修改iptables文件
设置:vi/etc/sysconfig/iptables
在行上面有22-jACCEPT下面另起一行输入跟那行差不多的,只是把22换成21,然后:wq保存。
还要运行下,重启iptables
重启:serviceiptablesrestart
关闭防火墙:serviceiptablesstop
禁用防火墙重启:chkconfigiptablesoff
1.5 启动vsftpd
命令:servicevsftpdstart
java客户端(代码)调用
packagecom.jonychen.util; importjava.io.FileInputStream; importjava.io.FileNotFoundException; importjava.io.IOException; importjava.io.InputStream; importjava.net.SocketException; importjava.util.Date; importjava.util.UUID; importorg.apache.commons.net.ftp.FTP; importorg.apache.commons.net.ftp.FTPClient; publicclassFtpUploadUtil{ privatestaticThreadLocalthreadLocal=newThreadLocal<>(); privatestaticThreadLocal threadLocalHost=newThreadLocal<>(); publicstaticvoidinit(Stringhost,intport,Stringusername,Stringpassword)throwsSocketException,IOException{ FTPClientclient=threadLocal.get(); if(client==null){ client=newFTPClient(); //1.连接 client.connect(host,port); //2.登录 client.login(username,password); threadLocal.set(client); threadLocalHost.set(host); } } publicstaticStringupload(InputStreamlocal,StringfileName,Stringpath)throwsSocketException,IOException{ StringdatePath=DateUtil.date2Str(newDate(),"/yyyy/MM/dd/"); //路径添加日期 path+=datePath; FTPClientclient=threadLocal.get(); Stringhost=threadLocalHost.get(); //3.指定文件上传路径(路径不存在返回false) booleanexists=client.changeWorkingDirectory(path); if(!exists){ StringpathArray[]=path.split("/"); Stringtemp="/"; for(Stringp:pathArray){ temp+=(p+"/"); //4.如果文件路径不存在,则创建(一次只能创建一级目录) client.makeDirectory(temp); } //重新指定文件上传路径 client.changeWorkingDirectory(path); } //5.指定文件类型 client.setFileType(FTP.BINARY_FILE_TYPE); //获取后缀 Stringsuffix=fileName.substring(fileName.lastIndexOf(".")); Stringuuid=UUID.randomUUID().toString(); //6.执行上传 client.storeFile(uuid+suffix,local); //7.退出 client.logout(); //8.断开连接 client.disconnect(); threadLocalHost.remove(); threadLocal.remove(); return"http://"+host+"/jonychen"+datePath+uuid+suffix; } publicstaticvoidmain(String[]args)throwsSocketException,IOException{ InputStreamlocal=newFileInputStream("D:\\Documents\\Pictures\\01.png"); init("192.168.178.161",21,"ftpuser","111111"); //上传路径 Stringres=upload(local,"code.png","/home/ftpuser/ego"); System.out.println(res); } }
总结
以上所述是小编给大家介绍的linux下vsftpd的安装及配置使用详细步骤,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!