服務(wù)器
vsftpd 是“very secure FTP daemon”的縮寫,安全性是它的一個(gè)的特點(diǎn)。
創(chuàng)新互聯(lián)建站專注于蒼溪網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供蒼溪營(yíng)銷型網(wǎng)站建設(shè),蒼溪網(wǎng)站制作、蒼溪網(wǎng)頁(yè)設(shè)計(jì)、蒼溪網(wǎng)站官網(wǎng)定制、微信小程序定制開(kāi)發(fā)服務(wù),打造蒼溪網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供蒼溪網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。vsftpd 是一個(gè) UNIX 類操作系統(tǒng)上運(yùn)行的服務(wù)器的名字,它可以運(yùn)行在諸如 Linux、BSD、Solaris、 HP-UNIX等系統(tǒng)上面,是一個(gè)完全免費(fèi)的、開(kāi)放源代碼的ftp服務(wù)器軟件,支持很多其他的 FTP 服務(wù)器所不支持的特征。
比如:非常高的安全性需求、帶寬限制、良好的可伸縮性、可創(chuàng)建虛擬用戶、支持IPv6、速率高等。
vsftpd是一款在Linux發(fā)行版中最受推崇的FTP服務(wù)器程序。特點(diǎn)是小巧輕快,安全易用。
1.1 安裝
命令:
yum install vsftpd -y
配置Vsftpd
安裝完之后我們要對(duì)它進(jìn)行配置,才能正常使用。
編輯vsftpd的配置文件
vi /etc/vsftpd/vsftpd.conf
在配置文件中找到“anonymous_enable=YES”,將YES改為No,將匿名登錄禁用。
添加開(kāi)機(jī)自動(dòng)啟動(dòng),
chkconfig vsftpd on
不確定是否已經(jīng)加入了開(kāi)機(jī)啟動(dòng)項(xiàng)可以運(yùn)行chkconfig –list進(jìn)行查看
1.2 創(chuàng)建用戶
命令:useradd ftpuser
指定密碼:passwd ftpuser
此用戶就是用來(lái)登錄ftp服務(wù)器用的。
這樣一個(gè)用戶建完,可以用這個(gè)登錄,記得用普通登錄不要用匿名了。登錄后默認(rèn)的路徑為 /home/ftpuser.
----------------------------------------------------------------------------------------------------------------------------------
設(shè)置FTP用戶的賬號(hào),例如賬號(hào)為“ftpuser1”,目錄為/home/ftpuser1,且設(shè)置不允許通過(guò)ssh登錄。
useradd -d /home/ftpuser -s /sbin/nologin ftpuser
設(shè)置賬號(hào)對(duì)應(yīng)的密碼,例如密碼為“ftpuser”
passwd ftpuser
1.3 開(kāi)啟selinux權(quán)限
VSFTPD是一個(gè)FTP服務(wù)器程序,然后SELinux是CentOS的防火墻組件。由于 vsftpd 默認(rèn)被 SELinux 攔截,所以會(huì)遇到的FTP以下的問(wèn)題:
1.226 Transfer done (but failed to open directory).(傳輸完成,但是打開(kāi)路徑失?。?br />
2.550 Failed to change directory(更改路徑失?。?br />
3.
553 Could not create file.
4.
或者干脆在發(fā)送了LIST命令以后,服務(wù)器沒(méi)響應(yīng),超時(shí)斷開(kāi)。
遇到這樣的問(wèn)題,通常是vsftpd 沒(méi)有足夠的權(quán)限,很有可能是被SELinux阻止了。
查看命令:getsebool -a | grep ftp
getsebool -a | grep ftpd #以下是顯示出來(lái)的權(quán)限,off是關(guān)閉權(quán)限,on是打開(kāi)權(quán)限 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 具有訪問(wèn)ftp根目錄,以及文件傳輸?shù)葯?quán)限。
設(shè)置命令:setsebool -p xxxxxx on
[root@bogon ~]# setsebool -P allow_ftpd_full_access on [root@bogon ~]# setsebool -P ftp_home_dir on
1.4 設(shè)置或關(guān)閉防火墻
因?yàn)閒tp默認(rèn)的端口為21,而centos默認(rèn)是沒(méi)有開(kāi)啟的,所以要修改iptables文件
設(shè)置:vi /etc/sysconfig/iptables
在行上面有22 -j ACCEPT 下面另起一行輸入跟那行差不多的,只是把22換成21,然后:wq保存。
還要運(yùn)行下,重啟iptables
重啟:service iptables restart
關(guān)閉防火墻:service iptables stop
禁用防火墻重啟:chkconfig iptables off
1.5 啟動(dòng)vsftpd
命令:service vsftpd start
java客戶端(代碼)調(diào)用
package com.jonychen.util; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.net.SocketException; import java.util.Date; import java.util.UUID; import org.apache.commons.net.ftp.FTP; import org.apache.commons.net.ftp.FTPClient; public class FtpUploadUtil { private static ThreadLocalthreadLocal = new ThreadLocal<>(); private static ThreadLocal threadLocalHost = new ThreadLocal<>(); public static void init(String host,int port,String username,String password) throws SocketException, IOException { FTPClient client = threadLocal.get(); if(client==null) { client = new FTPClient(); //1.連接 client.connect(host,port); //2.登錄 client.login(username,password); threadLocal.set(client); threadLocalHost.set(host); } } public static String upload(InputStream local,String fileName,String path) throws SocketException, IOException { String datePath = DateUtil.date2Str(new Date(),/yyyy/MM/dd/); //路徑添加日期 path+=datePath; FTPClient client = threadLocal.get(); String host = threadLocalHost.get(); //3.指定文件上傳路徑(路徑不存在返回false) boolean exists = client.changeWorkingDirectory(path); if(!exists) { String pathArray[] = path.split(/); String temp = /; for(String p:pathArray) { temp+=(p+/); //4.如果文件路徑不存在,則創(chuàng)建(一次只能創(chuàng)建一級(jí)目錄) client.makeDirectory(temp); } //重新指定文件上傳路徑 client.changeWorkingDirectory(path); } //5.指定文件類型 client.setFileType(FTP.BINARY_FILE_TYPE); //獲取后綴 String suffix = fileName.substring(fileName.lastIndexOf(.)); String uuid = UUID.randomUUID().toString(); //6.執(zhí)行上傳 client.storeFile(uuid+suffix, local); //7.退出 client.logout(); //8.斷開(kāi)連接 client.disconnect(); threadLocalHost.remove(); threadLocal.remove(); return http://+host+/jonychen+datePath+uuid+suffix; } public static void main(String[] args) throws SocketException, IOException { InputStream local = new FileInputStream(D:\\\\Documents\\\\Pictures\\\\01.png); init(192.168.178.161, 21, ftpuser, 111111); //上傳路徑 String res = upload(local, code.png,/home/ftpuser/ego); System.out.println(res); } }
總結(jié)
以上所述是小編給大家介紹的linux下vsftpd的安裝及配置使用詳細(xì)步驟,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!