FREEBSD6.0 架設(shè)FTP 服務(wù)器

我們有二種方式啟動(dòng) ftpd,一種是使用 standalone daemon,另一種是使用 inetd。inetd 是 UNIX 系統(tǒng)中一個(gè)強(qiáng)大的「超級(jí)服務(wù)器」,我們可以使用它來(lái)管理許多系統(tǒng)服務(wù),例如 telnet、ssh、ftp 等。大部份的系統(tǒng)服務(wù)都是使用 inetd 來(lái)啟動(dòng),使用它的好處在于可以統(tǒng)一管理各種服務(wù),并經(jīng)由它來(lái)設(shè)定服務(wù)規(guī)則,例如是否要阻擋某些 IP 來(lái)源等。不過(guò),使用 inetd 的方式缺點(diǎn)是每次有聯(lián)機(jī)要求時(shí),inetd 的 daemon 必須依聯(lián)機(jī)的種類去執(zhí)行相對(duì)映的指令,所以速度比較慢。
另一種啟動(dòng) FTP 的方式是使用 standalone daemon,也就是直接執(zhí)行 FTP daemon,當(dāng)它接收到新的聯(lián)機(jī)時(shí),就 fork() 出來(lái)處理,這種方式聯(lián)機(jī)建立的速度較快,比較適合專門的 FTP 服務(wù)器。
使用 inetd
我們先來(lái)介紹如何使用 inetd 的方式啟動(dòng) FTP 服務(wù)器。首先,請(qǐng)編輯 /etc/inetd.conf,將 ftp 設(shè)定開(kāi)頭的 # 移除:
ftp stream tcp nowait root /usr/libexec/ftpd ftpd -l ftp stream tcp6 nowait root /usr/libexec/ftpd ftpd -l |
接下來(lái),我們必須使用下列指令重跑 inetd:
# kill -1 `cat /var/run/inetd.pid`
現(xiàn)在您就可以開(kāi)始使用 FreeBSD 的 FTP 服務(wù)了。
使用獨(dú)立 Daemon
如果您要以獨(dú)立的 daemon 方式啟動(dòng) FTP,請(qǐng)先確定在 inetd.conf 中沒(méi)有啟動(dòng) FTP 服務(wù)。接下來(lái),請(qǐng)?jiān)谛略鲆粋€(gè)檔案 /usr/local/etc/rc.d/ftpd.sh 內(nèi)容如下:
#!/bin/sh ftpd_program="/usr/libexec/ftpd" ftpd_flags="-D -l" case $1 in start) echo "Starting FTPD" $ftpd_program $ftpd_flags ;; stop) echo "Stopping FTPD" killall ftpd ;; restart) $0 stop sleep 1 $0 start ;; esac |
編輯完后,我們必須將該檔案變成可執(zhí)行:
# chmod 755 /usr/local/etc/rc.d/ftpd.sh
接下來(lái),您就可以使用下列指令啟動(dòng) FTPD 了:
# /usr/local/etc/rc.d/ftpd.sh tart
如果您要停止 FTPD 服務(wù),則使用下列指令:
# /usr/local/etc/rc.d/ftpd.sh stop
15.2.2 編輯歡迎訊息
當(dāng)我們聯(lián)機(jī)到一個(gè) FTP 站臺(tái)時(shí),我們可以看到二個(gè)歡迎訊息,一個(gè)是登入前的訊息,另一個(gè)是登入后的訊息。以下列訊息為例:
# ftp localhost Trying ::1... Connected to localhost.alexwang.com. 220- Welcome to My FTP Server. 220- 220- This is a welcome message 220- 220- Nice to see you. 220 vmware.alexwang.com FTP server (Version 6.00LS) ready. Name (localhost:alex): 331 Password required for alex. Password: 230- This is the message of the day. 230- 230- It will be shown after user login. 230 User alex logged in. Remote system type is UNIX. Using binary mode to transfer files. ftp>
開(kāi)頭為 220- 的就是登入前的訊息,我們稱它為歡迎訊息。以 230- 為開(kāi)頭的是登入后的訊息,我們稱它為本日訊息 (Message of the day)。這二種訊息我們都可以自行設(shè)定。
如果您要設(shè)定的是登入前的訊息,請(qǐng)新增一個(gè)檔案 /etc/ftpwelcome,并將您的訊息寫入該文件中。以下為上述范例中的訊息內(nèi)容:
Welcome to My FTP Server. This is a welcome message Nice to see you. |
您不需要寫 220- 等數(shù)據(jù),F(xiàn)TP 服務(wù)器會(huì)自動(dòng)幫您加上這種代碼。而登入后的訊息是存放在 /etc/ftpmotd,您可以編輯該檔以進(jìn)行設(shè)定。
15.2.3 FTP 服務(wù)器管理
在啟動(dòng) FTP 服務(wù)器時(shí),我們可以加入一些參數(shù)以調(diào)整服務(wù)器的行為。例如,修改預(yù)設(shè)的連接端口、記錄使用者上傳、下載的檔案等等。有些參數(shù)必須要在使用獨(dú)立的 daemon 方式啟動(dòng)時(shí)才有用,而有的參數(shù)在 inetd 模式下也可以使用。
下表為我們常用的參數(shù):
參數(shù) | 是否只能在 Daemon 模式下使用 | 意義 |
-a | 是 | 當(dāng)您有二張網(wǎng)絡(luò)卡或是二個(gè) IP 時(shí),我們可以設(shè)定只接受聯(lián)機(jī)到某一個(gè) IP 的聯(lián)機(jī)要求。例如:
ftpd -D -a 192.168.0.1 此范例表示只接受使用者聯(lián)機(jī)到 192.168.0.1 這個(gè) IP。 |
-d | 否 | 記錄 FTP 的除錯(cuò)訊息。除了加入這個(gè)參數(shù)外,您必須修改 /etc/syslog.conf,并加入下列內(nèi)容以記錄 FTP 的訊息。
!ftpd *.* /var/log/ftpd.log |
-h | 否 | 不要顯示 FTP 服務(wù)器的主機(jī)名稱、軟件信息、版本等。 |
-l | 否 | 記錄 FTP 登入成功及失敗的訊息。如果您使用二次 -l,則使用者上傳、下載、刪除、建立目錄時(shí)都會(huì)留下記錄。預(yù)設(shè)的記錄會(huì)留在 /var/log/xferlog 中。 |
-P | 是 | 我們知道 FTP 預(yù)設(shè)會(huì)****連接埠 21,以接受客戶端的聯(lián)機(jī)要求。不過(guò)如果您是以獨(dú)立的 daemon 方式啟動(dòng) FTP,則 可以使用 -P 加上連接埠號(hào)以改變預(yù)設(shè)連接埠。 |
另外,還有很多用來(lái)控制使用者權(quán)限的參數(shù),我們會(huì)在下一小節(jié)中說(shuō)明。您也可以使用 man ftpd 以查看更多關(guān)于 ftpd 的參數(shù)。
如果您要修改 ftpd 啟動(dòng)的參數(shù),在 inetd 模式下,您可以修改 /etc/inetd.conf,并在 ftp 設(shè)定的最后面加入?yún)?shù),如下列粗體字所示:
ftp stream tcp nowait root /usr/libexec/ftpd ftpd -l -l -d ftp stream tcp6 nowait root /usr/libexec/ftpd ftpd -l -l -d |
上面的范例中,我們多加入了參數(shù) -l -d,以記錄更多 ftpd 的訊息。
如果您是以獨(dú)立的 Daemon 方式啟動(dòng) ftpd,則請(qǐng)修改 /usr/local/etc/rc.d/ftpd.sh:
#!/bin/sh ftpd_program="/usr/libexec/ftpd" ftpd_flags="-D -l -l -d" ... |
我們只要修改 ftpd_flags 的部份,加入您所要的參數(shù)即可。
15.3 FTP 權(quán)限控制
預(yù)設(shè)的 FTP 啟動(dòng)后,使用者可以上傳、下載任何他們有權(quán)存取的檔案。在登入后,使用者可以進(jìn)到任何系統(tǒng)中的目錄 (如果目錄權(quán)限允許的話)。本小節(jié)將告訴您一些 FTP 讀寫權(quán)限的控制,讓您可以更進(jìn)一步控制服務(wù)器的系統(tǒng)安全。
15.3.1 限制賬號(hào)與聯(lián)機(jī)來(lái)源
我們可以設(shè)定限制某些賬號(hào)不可以使用 FTP 登入。使用者在登入 FTP 服務(wù)器時(shí),有幾個(gè)規(guī)則會(huì)拒絕該賬號(hào)登入:
- 如果 /var/run/nologin 存在,則所有賬號(hào)都不可以登入。這個(gè)檔案可以用來(lái)暫時(shí)停止 FTP 服務(wù)。
- 使用者一定要有密碼才能登入,沒(méi)有密碼的使用者無(wú)法登入。
- 使用者名稱不可以出現(xiàn)在 /etc/ftpusers 中。
- 使用者群組不可以出現(xiàn)在 /etc/ftpusers 中。
- 使用者所使用的 shell 必須要時(shí)合法的 shell。合法的 shell 會(huì)被定義在 /etc/shells 中。
- 除了匿名模式外,使用者名稱不可以是 ftp 或 anonymous。關(guān)于匿名模式,我們會(huì)在下一小節(jié)中說(shuō)明。
/etc/ftpusers 定義了不可以使用 FTP 服務(wù)的使用者及群組。我們來(lái)看一下該檔案的內(nèi)容:
# $FreeBSD: src/etc/ftpusers,v 1.13 2004/06/30 16:47:08 maxim Exp $ # # list of users disallowed any ftp access. # read by ftpd(8). root toor daemon operator bin tty kmem games news @guest ... |
我們可以看到該檔案中已經(jīng)有一些使用者不可以登入 FTP。這些使用者都是系統(tǒng)預(yù)設(shè)的賬號(hào),我們也可以經(jīng)由修改它來(lái)加入其它使用者。
在 /etc/ftpusers 中,如果開(kāi)頭是 "@" 表示群組名稱。例如上述檔案內(nèi)容中的 @guest 表示群組 guest 不可以登入系統(tǒng)。
除了控制使用者賬號(hào)外,在「inetd」模式下,我們還可以控制聯(lián)機(jī)來(lái)源。所有 FreeBSD 中由 inetd 所啟動(dòng)的服務(wù)都可以經(jīng)由修改 /etc/hosts.allow 以使用 TCP Wrappd 來(lái)限制聯(lián)機(jī)來(lái)源。下列為預(yù)設(shè)的 /etc/hosts.allow 內(nèi)容:
# Provide a small amount of protection for ftpd ftpd : localhost : allow ftpd : .nice.guy.example.com : allow ftpd : .evil.cracker.example.com : deny ftpd : ALL : allow |
如果我們要限制某幾個(gè) IP 或網(wǎng)域不能使用 FTP,可以使用下列范例:
# Provide a small amount of protection for ftpd ftpd : localhost : allow ftpd : 210.122.13.5 : deny ftpd : .evil.cracker : deny ftpd : ALL : allow |
我們?cè)谏鲜龇独芯芙^ IP 210.122.13.5 及 evil.cracker 網(wǎng)域的主機(jī)使用 FTP,并在最后一行設(shè)定其它來(lái)源都許可。
如果您要設(shè)定只有某些來(lái)源可以使用 FTP,而拒絕大多數(shù)的主機(jī),則可以設(shè)定:
# Provide a small amount of protection for ftpd ftpd : localhost : allow ftpd : 192.168.0. : allow ftpd : my.friend.com : allow ftpd : ALL : deny |
我們?cè)O(shè)定了只有本機(jī) (localhost)、192.168.0.x、及 my.friend.com 才可以使用 FTP,其它聯(lián)機(jī)都拒絕。
15.3.2 限制上傳下載權(quán)限
在使用者登入后,只要目錄、檔案權(quán)限許可,它們可以自由的上傳、下載檔案。如果您希望加以限制讀寫的權(quán)限,可以在啟動(dòng) FTP 時(shí)加上下列幾個(gè)參數(shù):
參數(shù) | 意義 |
-o | 限制所有使用者只能上傳檔案,而無(wú)法下載任何檔案。 |
-r | 限制所有使用者對(duì)于服務(wù)器內(nèi)所有檔案只能只讀,不可以建立目錄、上傳、更改檔名、或任何會(huì)動(dòng)到檔案目錄的指令。 |
上述的參數(shù)必須在啟動(dòng) FTP 服務(wù)器時(shí)指定,請(qǐng)參考15.2.3 一節(jié),針對(duì) inetd 及獨(dú)立的 Daemon 有不同的設(shè)定方法。
15.3.3 chroot
一般使用者登入后,預(yù)設(shè)會(huì)進(jìn)入自己的家目錄中。使用者可以改變工作路徑到系統(tǒng)的任何目錄中。如果您希望使用者登入后只能在自己的家目錄中活動(dòng),而不能進(jìn)入其它系統(tǒng)目錄中,可以使用 chroot 的功能。
所謂的 chroot 就是將某一個(gè)目錄變成使用者看到的根目錄。例如,我們讓使用者 alex 登入后,將 /home/alex 變成根目錄。則 alex 在使用指令「cd /」時(shí),還是會(huì)停留在 /home/alex。如果他使用指令「pwd」查看目前所在路徑,則會(huì)顯示 /。如此一來(lái),我們就可以確保使用者不會(huì)到處亂跑,進(jìn)入一些不該進(jìn)入的地方。這個(gè)功能對(duì)于提升 FTP 的安全性有莫大的助益。
設(shè)定 chroot 的方法很簡(jiǎn)單,只要修改 /etc/ftpchroot 即可。chroot 的設(shè)定是以使用者、群組的基礎(chǔ),以下是幾個(gè)設(shè)定范例:
alex @guest john /var/ftp @other /var/ftp |
上述范例中的第一行是設(shè)定使用者 alex 登入后,以自己的家目錄為根目錄。第二行的 @guest 表示只要是群組為 guest 的使用者,都以自己的家目錄為根目錄。而第三、四行分別表示使用者 john 及群組 other 都以 /var/ftp 為根目錄。
只要我們善用 chroot 的功能,就可以加強(qiáng)保護(hù)系統(tǒng)其它目錄,讓沒(méi)有權(quán)利的使用者不可以進(jìn)入系統(tǒng)目錄中。建議您在開(kāi)放 FTP 服務(wù)時(shí),將所有使用者都加入 /etc/ftpchroot 中。
15.3.4 匿名的 FTP
我們平常在登入 FreeBSD 的 FTP 站臺(tái)時(shí),可以使用 anonymous 或是 ftp 這二個(gè)使用者登入,而且在登入時(shí),任何密碼都可以通過(guò)。這種可以使用 anonymous 登入的 FTP 就叫作匿名 FTP。anonymous 及 ftp 這二個(gè)賬號(hào)是預(yù)設(shè)的匿名賬號(hào),當(dāng)使用者以匿名登入時(shí),服務(wù)器會(huì)將匿名賬號(hào)對(duì)映到系統(tǒng)內(nèi)的真實(shí)使用者 ftp。所以,如果您要提供匿名的 FTP 服務(wù),請(qǐng)使用下列指令新增使用者賬號(hào) ftp:
# pw adduser ftp # mkdir /home/ftp # chown ftp:ftp /home/ftp
我們建立了使用者 ftp 及其家目錄 /home/ftp。使用 pw 指令所建立的使用者在 /etc/master.passwd 中的密碼字段預(yù)設(shè)為 *,表示不可以登入。這個(gè)使用者除了匿名 FTP 外,將不可以使用 telnet、SSH、或是其它服務(wù)。
在新增了使用者 ftp 之后,我們就已經(jīng)支持匿名 FTP 的功能了。現(xiàn)在您可以使用 anonymous 或 ftp 賬號(hào)登入,而且不需任何密碼。由于開(kāi)放了匿名 FTP 后,任何人都可以登入系統(tǒng),所以匿名賬號(hào)登入后一定會(huì)使用 chroot,以將匿名使用者限制在家目錄中。
除了強(qiáng)制使用 chroot 外,我們還可以在啟動(dòng) FTP 時(shí)加上一些參數(shù),以針對(duì)匿名使用者進(jìn)行更多的限制。下表為啟動(dòng) FTP 服務(wù)時(shí)可以使用的參數(shù):
參數(shù) | 意義 |
-M | 禁止匿名使用者建立新的目錄。 |
-m | 允許匿名使用者覆寫一個(gè)存在的檔案。預(yù)設(shè)啟動(dòng) FTP 時(shí),并不允許匿名使用者覆寫已經(jīng)存在的檔案。當(dāng)使用者上傳檔案時(shí),如果已經(jīng)有同檔名的檔案存在,系統(tǒng)會(huì)自動(dòng)為上傳的檔案改名。 |
-O | 讓匿名使用者只能上傳檔案,下載檔案的功能會(huì)被取消。 |
匿名使用者權(quán)限除上表中的幾個(gè)參數(shù)外,一樣可以使用 -r、-o 等用來(lái)控制一般使用者權(quán)限的參數(shù)來(lái)控制匿名使用者。
匿名的 FTP 服務(wù)器可以說(shuō)是危險(xiǎn)的開(kāi)始,如果您沒(méi)有對(duì)匿名的使用者進(jìn)行權(quán)限控制,在開(kāi)于匿名 FTP 后,將會(huì)產(chǎn)生許多安全性的問(wèn)題。最常見(jiàn)的就是您的 FTP 服務(wù)器會(huì)被做為檔案交流的跳板或是病毒的集散地。例如,當(dāng)您的匿名 FTP 站臺(tái)允許使用者上傳、下載檔案時(shí),一定會(huì)有人將自己的檔案上傳到您的服務(wù)器中,并告訴其它人可以到您的服務(wù)器中下載檔案。此時(shí),您的服務(wù)器莫名其妙就會(huì)變成別人的服務(wù)器,任何人都可以用您的服務(wù)器、網(wǎng)絡(luò)頻寬來(lái)分享檔案。所以,在匿名模式下,最好還是在啟動(dòng) FTP 時(shí)加上參數(shù) -r 以取消上傳的功能吧。
15.4 SmbFTPD
SmbFTPD 是筆者從 FreeBSD 5.4 的 FTP daemon 修改而成的軟件。FreeBSD 內(nèi)建的 FTP 服務(wù)器比較簡(jiǎn)單,它不支持流量控制、不支持 SSL 加密、對(duì)中文檔名的支持也比較差。例如,您無(wú)法使用「許」、「功」等中文字。SMbFTPD 除了擁有原本 FreeBSD ftpd 所有功能外,還有更多使用者權(quán)限控制、支持特殊中文字、整合設(shè)定文件路徑及更多功能。另外,它也支持 SSL/TLS 加密的功能,該功能是由 BSDftpd-ssl 移植而來(lái)。
SmbFTPD 和一般 FTP daemon 最大的不同在于它使用類似 Samba 的數(shù)據(jù)夾權(quán)限設(shè)定,您可以設(shè)定讓 FTP 使用者登入后所看到的目錄跟使用 Windows 登入 Samba 時(shí)一模一樣。也就是說(shuō) FTP 登入的使用者對(duì)于數(shù)據(jù)夾的存取權(quán)限和使用 Windows 登入 Samba 一模一樣。
而您也可以將 SmbFTPD 做為一般 FTP daemon 使用,或同時(shí)支持 Samba 模式。FreeBSD 的 FTP daemon 本來(lái)效能就很好,修改過(guò)的 SmbFTPD 效能也十分優(yōu)越,而且程序文件本身體積很小。
- 效能優(yōu)越。
- 檔案很小 (約 70KB),占用內(nèi)存空間小。
- 支援 SSL/TLS 加密。
- 可以更改 port。
- 針對(duì)使用者、群組做流量控制。
- 針對(duì)使用者、群組設(shè)定 chroot 的路徑。
- 類似 Samba 的數(shù)據(jù)夾權(quán)限,可以針對(duì)目錄設(shè)定使用者的讀寫權(quán)限。
- 限制 FTP 指令的使用,如上傳、下載等。
- 匿名使用者登入。
- 諸多匿名使用者的權(quán)限控制。
- 同時(shí)支持 Samba 權(quán)限控制模式及一般 FTP 模式。
- 可以拒絕某些使用者 "ls" 出某一個(gè) share 下的檔案。
- 可以拒絕某些使用者下載檔案或是修改已存在的檔案。
- 可以讓某個(gè)數(shù)據(jù)夾處于只能上傳的模式。
15.4.1 安裝 SmbFTPD
您可以到 http://www.twbsd.org/cht/smbftpd/index.php 下載最新版的 SmbFTPD,下載 SmbFTPD 后,解壓縮后進(jìn)行該目錄。接著您就可以執(zhí)行下列指令進(jìn)行編譯:
# ./configure # make
configure 指令會(huì)偵測(cè)您的系統(tǒng),并依您的環(huán)境以決定編譯時(shí)所要加入的功能。例如,是否支持 IPv6、SSL/TLS、TCP Wrapper、或是 PAM 等。
編譯完成后,如果您支持 SSL/TLS,您必須有 SSL 憑證。如果您有安裝 Apache+SSL,您也可以和 Apache 共享它的憑證。如果您要產(chǎn)生憑證,您必須再執(zhí)行下列指令以產(chǎn)生憑證。
# make cert
執(zhí)行上述指令后,我們會(huì)先產(chǎn)生一個(gè)根憑證,再產(chǎn)生 FTP 所使用的憑證,接著再用我們產(chǎn)生的根憑證為 FTP 用的憑證簽章。全部都完成后,我們就可以使用下列指令來(lái)安裝:
# make install
和 FreeBSD 內(nèi)建的 FTP 服務(wù)器一樣,SmbFTPD 可以使用 inetd 或是獨(dú)立的 Daemon 方式啟動(dòng)。如果您要使用 inetd 的方式啟動(dòng) SmbFTPD,請(qǐng)修改 /etc/inetd.conf 并加入下列內(nèi)容:
ftp stream tcp nowait root /usr/local/sbin/smbftpd smbftpd |
接下來(lái)請(qǐng)執(zhí)行下列指令重跑 inetd:
# kill -1 `cat /var/run/inetd.pid`
如果您要以獨(dú)立的 Daemon 方式啟動(dòng) SmbFTPD,請(qǐng)先在 /etc/rc.conf 加入下列這一行,以在開(kāi)機(jī)時(shí)啟動(dòng) SmbFTPD:
smbftpd_enable="Yes" |
接下來(lái)就可以使用下列指令看看是否能啟動(dòng) SmbFTPD:
# /usr/local/etc/rc.d/smbftpd.sh start
如果您要停止 SmbFTPD:
# /usr/local/etc/rc.d/smbftpd.sh stop
SmbFTPD 是由 FreeBSD 的 FTP Deamon 改寫而成,所以有些設(shè)定和 FreeBSD 的 FTPD 相同。例如登入前及登入后的訊息可以經(jīng)由設(shè)定 /etc/ftpwelcome 及 /etc/ftpmotd 這二個(gè)檔來(lái)達(dá)成。另外,您也可以設(shè)定 /etc/hosts.allow 以限制聯(lián)機(jī)來(lái)源。不同的是,不管是以獨(dú)立的 Daemon 或是 inetd 方式啟動(dòng) SmbFTPD,都可以使用 hosts.allow 的功能。
另外,SmbFTPD 將所有設(shè)定項(xiàng)目放在 /usr/local/etc/smbftpd/smbftpd.conf 中,您可以經(jīng)由修改它來(lái)客制化您的服務(wù)器。經(jīng)由修改 smbftpd.conf,您可以設(shè)定使用不同的連接埠、更改服務(wù)器名稱、設(shè)定最大聯(lián)機(jī)數(shù)目、目錄權(quán)限、流量控制、SSL 設(shè)定等等。
下列幾個(gè)小節(jié)中,我們將介紹一些比較特別的設(shè)定,關(guān)于更多選項(xiàng)及其詳細(xì)的設(shè)定請(qǐng)參考 smbftpd.conf 一章中的說(shuō)明。
15.4.2 限制登入賬號(hào)
我們可以設(shè)定限制某些賬號(hào)不可以使用 FTP 登入。使用者在登入 FTP 服務(wù)器時(shí),除了賬號(hào)密碼要符合外,還有幾個(gè)規(guī)則會(huì)拒絕該賬號(hào)登入:
- 如果 /var/run/nologin 存在,則所有賬號(hào)都不可以登入。這個(gè)檔案可以用來(lái)暫時(shí)停止 FTP 服務(wù)。
- 如果 smbftpd.conf 中 EmptyPasswdLogin 沒(méi)有設(shè)為 Yes,則使用者一定要有密碼才能登入,沒(méi)有密碼的使用者無(wú)法登入。
- 使用者名稱及群組不可以出現(xiàn)在 smbftpd.conf 中的 NoLoginList 中。
- 如果 smbftpd.conf 中 RequireValidShell 設(shè)為 Yes,則使用者所使用的 shell 必須要時(shí)合法的 shell。合法的 shell 會(huì)被定義在 /etc/shells 中。
我們可以看到在 smbftpd.conf 中有三個(gè)選項(xiàng)控制了使用者可以登入與否:EmptyPasswdLogin、NoLoginList、RequrieValidShell。 其中,NoLoginList 這個(gè)項(xiàng)目可以讓我們?cè)O(shè)定不允許登入的使用者清單。
我們?cè)?a target="_blank" href="http://www.dbjr.com.cn" class="UBBWordLink">安裝了 SmbFTPD 后,即限制了某些系統(tǒng)使用者登入。我們來(lái)看一下該選項(xiàng)的內(nèi)容:
NoLoginList root,toor,daemon,operator,lp,bin,tty,shutdown,kmem,... |
這個(gè)項(xiàng)目中,每個(gè)使用者或群組都是使用逗號(hào)分開(kāi)。如果一個(gè)項(xiàng)目的開(kāi)頭是 "@" 表示群組名稱。例如 @guest 表示群組 guest 不可以登入系統(tǒng)。
15.4.3 限制上下傳頻寬
SmbFTPD 支持針對(duì)不同的使用者設(shè)定不同的上下傳頻寬限制。smbftpd.conf 中的 MaxDownloadRate 及 MaxUploadRate 控制了使用者上下傳的頻寬。
這二個(gè)選項(xiàng)可以重復(fù)設(shè)定多次,以支持多個(gè)使用者及群組。MaxDownloadRate 及 MaxUploadRate 的格式如下:
MaxDownloadRate @group|user rate
其格式就是在選項(xiàng)后面加上群組或使用者名稱,最后再加上頻寬的限制,頻寬是以 KB/s 為單位。如果是群組名稱,其開(kāi)頭必須加上 "@"。我們來(lái)看看下列的設(shè)定范例:
MaxDownloadRate @group100 100 MaxDownloadRate ftp 20 MaxDownloadRate @friends 1000 |
我們可以看到目前有三個(gè)控制下傳頻寬的項(xiàng)目。第一個(gè)項(xiàng)目表示群組為 group100 的使用者,其下載頻寬為 100 KB/s。第二個(gè)項(xiàng)目表示使用者 ftp 的下載頻寬為 20 KB/s。如果您支持匿名的 FTP,匿名 FTP 使用者對(duì)于系統(tǒng)而言實(shí)質(zhì)賬號(hào)是 ftp,您只要針對(duì) ftp 使用者做設(shè)定即可套用在匿名使用者 anonymous 及 ftp 上。
15.4.4 匿名的 FTP
我們平常在登入 FreeBSD 的 FTP 站臺(tái)時(shí),可以使用 anonymous 或是 ftp 這二個(gè)使用者登入,而且在登入時(shí),任何密碼都可以通過(guò)。這種可以使用 anonymous 登入的 FTP 就叫作匿名 FTP。anonymous 及 ftp 這二個(gè)賬號(hào)是預(yù)設(shè)的匿名賬號(hào),當(dāng)使用者以匿名登入時(shí),服務(wù)器會(huì)將匿名賬號(hào)對(duì)映到系統(tǒng)內(nèi)的真實(shí)使用者 ftp。所以,如果您要提供匿名的 FTP 服務(wù),必須先增加一個(gè)真實(shí)的使用者賬號(hào) ftp。
在新增了使用者 ftp 之后,我們還必須設(shè)定一下 smbftpd.conf 中關(guān)于匿名登入的項(xiàng)目。在 smbftpd 中,關(guān)于匿名 FTP 的項(xiàng)目有:AnonymousLogin、AnonymousOnly。
AnonymousLogin 控制了是否要啟用匿名使用者登入的功能。如果 AnonymousLogin 設(shè)為 Yes,表示可以使用匿名使用者登入。另外,AnonymousOnly 控制了在允許匿名使用者登入后,是否還要允許一般使用者登入。如果 AnonymousOnly 設(shè)為 Yes,則只有匿名使用者才可以登入,一般使用者都不可以登入哦。
請(qǐng)注意,雖然匿名使用者登入的賬號(hào)有二個(gè):anonymous 及 ftp。但我們不管是在設(shè)定流量、目錄權(quán)限時(shí),都只要設(shè)定真實(shí)使用者 "ftp" 賬號(hào)即可。
15.5 SmbFTPD 的目錄權(quán)限控制
15.5.1 何謂 SMB Mode
SmbFTPD 和一般的 FTP 服務(wù)器最大的不同在于它的目錄權(quán)限管理方式。SmbFTPD 有二種目錄權(quán)限管理方式:一般模式及 SMB 模式。一般模式下,SmbFTPD 的行為就和一般的 FTP 服務(wù)器一樣,使用者登入后可以看到所有的系統(tǒng)目錄。
SMB 模式比較特別,它會(huì)依照您的設(shè)定產(chǎn)生一個(gè)虛擬的根目錄,在根目錄中,只會(huì)顯示該使用者可以使用的資料夾。如果您使用過(guò) Samba,SmbFTPD 的 SMB 模式就和 Samba 的共享數(shù)據(jù)夾設(shè)定類似。例如,您可以設(shè)定一個(gè)數(shù)據(jù)夾名為「音樂(lè)」,它的真實(shí)目錄是在 /home/mp3,并可以設(shè)定哪些使用者可以存取此數(shù)據(jù)夾、只讀或可擦寫、是否可以下載檔案等等。
以下列數(shù)據(jù)夾設(shè)定文件為例:
[音樂(lè)] path = /home/mp3 rw = alex ro = @guest, john disable_download = ftp [upload] path = /var/ftp rw = ftp,alex disable_ls = ftp disable_download = ftp |
上述的范例中,我們有二個(gè)共享數(shù)據(jù)夾:「音樂(lè)」及「upload」。其中,path 為該數(shù)據(jù)夾位于系統(tǒng)中的真實(shí)目錄。rw 為具有讀寫權(quán)限的使用者 清單,而 ro 為只讀的使用者清單。在上述的設(shè)定下,使用者 alex 登入后,如果他在根目錄中下「ls」指令,他將看到下列內(nèi)容:
ftp> ls / 200 PORT command successful. 150 Opening ASCII mode data connection for 'file list'. dr-x------ 1 root users 512 Feb 3 21:40 音樂(lè) dr-x------ 1 root users 2048 Aug 28 03:18 upload 226 Transfer complete. ftp> |
我們可以看到使用者 alex 登入后,他所看到的根目錄只有二個(gè)數(shù)據(jù)夾:「音樂(lè)」及「upload」。他的活動(dòng)范圍也將只限于這二個(gè)數(shù)據(jù)夾,而無(wú)法進(jìn)入系統(tǒng)中的其它目錄。也就是說(shuō),如果 alex 輸入指令「cd /upload」則會(huì)進(jìn)入「upload」這個(gè)數(shù)據(jù)夾中 (在系統(tǒng)中的真正路徑是 /var/ftp)。
SMB 模式的好處在于您可以將不同目錄集中設(shè)定成位于虛擬的根目錄中,并針對(duì)這些目錄設(shè)定不同使用者的權(quán)限。使用者權(quán)限可以是只讀、可擦寫、禁止下載檔案、禁止看到目錄中的檔案內(nèi)容,您甚至可以設(shè)定其一個(gè)資料夾為隱藏,「ls」時(shí)看不到該目錄,但卻可以「cd」進(jìn)入目錄中。
SMB 模式是一個(gè)比較有彈性的目錄權(quán)限管理方式,您可以經(jīng)由設(shè)定 SMB 模式達(dá)到多種不同的目錄權(quán)限控制。
我們還可以讓某些使用者使用一般模式,某些使用者使用 SMB 模式。這些設(shè)定十分容易,我們將在下一小節(jié)中做說(shuō)明。
15.5.2 如何設(shè)定 SMB Mode
在 smbftpd.conf 中有三個(gè)選項(xiàng)和 SMB 模式的目錄權(quán)限管理有關(guān):DefaultMode、ExceptionList、ShareConfPath。
DefaultMode 設(shè)定了預(yù)設(shè)的目錄權(quán)限管理模式為何,而 ExecptionList 為例外的清單。如果 DefaultMode 為 Normal,而 ExceptionList 中有使用者 alex,則除了 alex 會(huì)使用 SMB 模式外,其它使用者都會(huì)使用一般模式。反之,如果 DefaultMode 為 SMB,則 ExceptionList 中的使用者或群組將使用一般模式,其它的使用者會(huì)使用 SMB 模式的目錄權(quán)限管理方式。
ShareConfPath 設(shè)定了共享數(shù)據(jù)夾設(shè)定文件的位置,預(yù)設(shè)為 /usr/local/etc/smbftpd/smbftpd_share.conf。每一個(gè)以中括號(hào)括起來(lái)的區(qū)段都是一個(gè)數(shù)據(jù)夾的設(shè)定,下列即為數(shù)據(jù)夾設(shè)定的范例:
[音樂(lè)] path = /home/mp3 rw = alex ro = @guest, john disable_download = ftp |
每一個(gè)資料夾的區(qū)段都有下列這幾個(gè)關(guān)鍵詞可用:
- path:設(shè)定數(shù)據(jù)夾的實(shí)際路徑。
- rw:設(shè)定具有讀寫權(quán)限的使用者及群組。
- ro:設(shè)定只能進(jìn)行只讀的使用者及群組。
- disable_download:設(shè)定禁止使用下載功能的使用者及群組。
- disable_ls:設(shè)定在數(shù)據(jù)夾中 ls 看不到數(shù)據(jù)夾內(nèi)容的使用者及群組。
- disable_modify:設(shè)定不可以修改此資料夾中已經(jīng)在的檔案之使用者及群組。在此項(xiàng)目中的使用者或群組無(wú)法更名、刪除、修改已存在的檔案或目錄,只能上傳及建立新目錄。但前提是使用者必須具有 rw 的權(quán)限。
- browseable:設(shè)定此數(shù)據(jù)夾在列出根目錄的所有數(shù)據(jù)夾時(shí)是否要顯示。這個(gè)項(xiàng)目只能設(shè)定 Yes 或 No,如果設(shè)定為 No,則使用者 「ls /」時(shí)將看不到此數(shù)據(jù)夾,但可以使用「cd」指令進(jìn)入該數(shù)據(jù)夾內(nèi)。
除了 path 及 browseable 外,每一個(gè)項(xiàng)目可以加上使用者及群組的設(shè)定。如果是群組名稱,其開(kāi)頭必須加上 "@" 符號(hào)。例如,上述范例中,@guest 表示 guest 群組。
您必須要特別注意的是,當(dāng)您設(shè)定了使用者對(duì)于數(shù)據(jù)夾的權(quán)限是只讀或可擦寫后,該使用者或群組在系統(tǒng)中的 UNIX 權(quán)限也必須要符合設(shè)定才會(huì)有作用。例如,如果一個(gè)數(shù)據(jù)夾對(duì)使用者 alex 設(shè)定為可擦寫,您必須確定 alex 對(duì)于數(shù)據(jù)夾在系統(tǒng)中的權(quán)限是可擦寫,如果不是,您必須使用 chmod 的指令改變?cè)撃夸浀膶傩浴?/p>
另外,我們有一個(gè)特別的數(shù)據(jù)夾名稱「homes」,如果有 homes 這個(gè)數(shù)據(jù)夾的設(shè)定,則使用者登入后會(huì)看到一個(gè)數(shù)據(jù)夾名為「home」,該數(shù)據(jù)夾即為使用者的家目錄。家目錄預(yù)設(shè)是該使用者具有讀寫的權(quán)限,所以您無(wú)法設(shè)定 rw、ro 這二個(gè)參數(shù)。而且,您也無(wú)法設(shè)定 path,使用者家目錄的所在路徑是由系統(tǒng)密碼文件中的設(shè)定而決定。您只能設(shè)定 browseable、disable_ls、disable_modify、及 disable_download。
如果您的 SmbFTPD 支持匿名使用者,匿名使用者 anonymous 及 ftp 會(huì)被對(duì)映到真實(shí)的使用者 ftp,您只要針對(duì) ftp 使用者做設(shè)定即會(huì)套用在匿名使用者上。
在修改了 smbftpd_share.conf 后,您必須重新啟動(dòng) SmbFTPD 后設(shè)定才會(huì)生效。
15.5.3 設(shè)定范例
我們列舉幾個(gè)設(shè)定的范例讓您參考。
范例一:
我們?cè)O(shè)定一個(gè)數(shù)據(jù)夾名為「public」,其真實(shí)路徑是 /home/public。只有 wheel 群組的使用者具有讀寫權(quán)限,而匿名使用者及 guest 群組只具有只讀的權(quán)限。
[public] path = /home/public rw = @wheel ro = @guest, ftp |
范例二:
我們?cè)O(shè)定一個(gè)數(shù)據(jù)夾名為「private」,其真實(shí)路徑是 /home/movie。只有使用者 alex 具有讀寫的權(quán)限,而 friend 群組只能只讀,另外,guest 群組的使用者無(wú)法下載該數(shù)據(jù)夾中的任何檔案。
[public] path = /home/movie rw = alex ro = @guest, @friend disable_download = @guest |
范例三:
我們?cè)O(shè)定一個(gè)數(shù)據(jù)夾名為「upload」,其真實(shí)路徑是 /var/ftp/pub。只有使用者 alex 具有完整的讀寫權(quán)限,匿名使用者無(wú)法下載檔案、看不到目錄中的檔案、無(wú)法修改目錄中的檔案、只能上傳檔案。
[upload] path = /var/ftp/pub rw = alex,ftp disable_download = ftp disable_modify = ftp disable_ls = ftp |
15.5.4 chroot
我們除了可以使用 SMB 模式以創(chuàng)造出虛擬的根目錄外,SmbFTPD 還支持 chroot 的功能。
所謂的 chroot 就是將某一個(gè)目錄變成使用者看到的根目錄。例如,我們讓使用者 alex 登入后,將 /home/alex 變成根目錄。則 alex 在使用指令「cd /」時(shí),還是會(huì)停留在 /home/alex。如果他使用指令「pwd」查看目前所在路徑,則會(huì)顯示 /。如此一來(lái),我們就可以確保使用者不會(huì)到處亂跑,進(jìn)入一些不該進(jìn)入的地方。這個(gè)功能對(duì)于提升 FTP 的安全性有莫大的助益。
當(dāng)一個(gè)使用者同時(shí)屬于 SMB 模式及 chroot 時(shí),我們會(huì)使用 chroot 而非 SMB 模式。
設(shè)定 chroot 的方法很簡(jiǎn)單,只要修改 smbftpd.conf,將使用者加入 ChrootSet 即可。ChrootSet 選項(xiàng)的設(shè)定是以使用者、群組的基礎(chǔ),我們可以同時(shí)設(shè)定多個(gè) ChrootSet。以下是幾個(gè)設(shè)定范例:
ChrootSet ftp /var/spool/ftp ChrootSet @ftpgroup ~ ChrootSet @webusers ~/public_html |
上述范例中的第一行是設(shè)定所有匿名的使用者都以 /var/spool/ftp 為根目錄。第二行表示只要是群組為 ftpgroup 的使用者都以自己的家目錄為根目錄。而第三行表示只要是群組為 webusers 的使用者都以自己家目錄下的 public_html 為根目錄。
在 ChrootSet 的選項(xiàng)中,群組名稱開(kāi)頭都會(huì)有 "@" 符號(hào)。而目錄名稱 "~" 表示是使用者的家目錄。
另外,如果只有一個(gè) "@" 符號(hào),表示所有使用者。下列范例即表示所有的使用者都以自己的家目錄為根目錄:
ChrootSet @ ~ |
只要我們善用 chroot 的功能,就可以加強(qiáng)保護(hù)系統(tǒng)其它目錄,讓沒(méi)有權(quán)利的使用者不可以進(jìn)入系統(tǒng)目錄中。
15.6 SSL/TLS 聯(lián)機(jī)加密
15.6.1 設(shè)定啟用 SSL/TLS
當(dāng)我們使用網(wǎng)絡(luò)服務(wù)時(shí),經(jīng)由網(wǎng)絡(luò)傳送的數(shù)據(jù)都有可能被他人攔截竊聽(tīng)。簡(jiǎn)單的說(shuō),當(dāng)您從網(wǎng)頁(yè)上輸入賬號(hào)密碼時(shí),如果有人在您所使用的計(jì)算機(jī)和服務(wù)器之間攔截,就可以輕易的從網(wǎng)絡(luò)封包中竊聽(tīng)到您所輸入的數(shù)據(jù)。
SSL 的加密方式是由服務(wù)器端提供了一組加解密用的金鑰,在服務(wù)器端所使用的是私密金鑰 (Private key),而客戶端所使用的是公開(kāi)金鑰 (Public key)。在聯(lián)機(jī)建立后,HTTP 服務(wù)器會(huì)將公開(kāi)金鑰傳給客戶端使用。公開(kāi)金鑰加密過(guò)的資料只能由私密金鑰解密,在客戶端要送出數(shù)據(jù)之前,會(huì)先使用公開(kāi)金鑰進(jìn)行加密的動(dòng)作,而服務(wù)器收到數(shù)據(jù)后,會(huì)使用私密金鑰進(jìn)行解密。
如果您的系統(tǒng)有安裝 OpenSSL,則 SmbFTPD 安裝后即支持 SSL 的功能。在下列 configure 的訊息中,「Check SSL support」為「YES」表示有支持 SSL。
# ./configure opie.................. [YES] libutil.h............. [YES] O_EXLOCK.............. [YES] FD_COPY............... [YES] TCP Wrapper........... [YES] Have printflike....... [YES] pw_expire............. [YES] bsd glob.............. [YES] MD5File............... [YES] user_from_uid......... [YES] Shadow passowd........ [NO] Linux sendfile........ [NO] FreeBSD sendfile...... [YES] Use PAM............... [YES] Check setproctitle.... [YES] Check fgetln.......... [YES] Check sin_len......... [YES] Check IPv6 support.... [YES] Check SSL support..... [YES] Finished configure.
在執(zhí)行完 configure 及 make 之后,即完成編譯。在安裝前,我們會(huì)執(zhí)行「make cert」以產(chǎn)生 SSL 憑證。最后「make install」會(huì)將 SSL 憑證安裝在 /usr/local/etc/smbftpd/ 目錄中。
在啟動(dòng) SmbFTPD 之前,您必須先設(shè)定 smbftpd.conf 以啟用 SSL 功能。smbftpd.conf 中所有 SSL 相關(guān)的選項(xiàng)說(shuō)明請(qǐng)參考下一章的說(shuō)明,我們這里只說(shuō)明幾個(gè)常用的項(xiàng)目。
首先是「SecurityPolicy」,這個(gè)項(xiàng)目用來(lái)控制是否要啟用 SSL 的功能?!竤ecure」 為只允許使用 SSL 聯(lián)機(jī),「nosecure」 為不使用 SSL 聯(lián)機(jī),「both」 為二種聯(lián)機(jī)都支持,預(yù)設(shè)為 「both」。
「NormalUserMustSecure」用來(lái)控制是否要強(qiáng)制一般使用者使用 SSL 聯(lián)機(jī)。因?yàn)?SSL 主要是用來(lái)保護(hù)密碼、個(gè)人數(shù)據(jù),如果您強(qiáng)制將「NormalUserMustSecure」設(shè)為 Yes,則一般使用者一定要使用 SSL 才能登入。
「AnonymDisableSecure」用以控制匿名使用者是否要使用 SSL。當(dāng) AnonymDisableSecure 設(shè)為「Yes」時(shí),系統(tǒng)將不允許匿名的使用者使用加密的聯(lián)機(jī)。既然 SSL/TLS 的目的是避免使用者數(shù)據(jù)在網(wǎng)絡(luò)上流傳,而匿名使用者是任何人都可以使用,保護(hù)匿名使用者的數(shù)據(jù)似乎比較不需要。所以您可以將這個(gè)選項(xiàng)設(shè)為「No」,以避免匿名使用者也使用加密聯(lián)機(jī)登入,徒然耗費(fèi) CPU 的資源。
15.6.2 安裝支持 SSL/TLS 的客戶端軟件
在支持 SSL/TLS 的客戶端軟件方面,如果您使用 Windows,建議您使用 Filezilla (http://filezilla.sourceforge.net/)。Filezilla 支持 SSL 及 TLS,而且 FTP client 的功能相當(dāng)完整。它是一套免費(fèi)、持續(xù)更新中的軟件。
如果您使用 FreeBSD,可以使用下列指令安裝 ftp-tls:
# cd /usr/ports/ftp/ftp-tls # make install
接下來(lái)您就可以使用下列指令連到您的 FTP Server 了:
# /usr/bin/ftp-tls 192.168.0.1
15.7 smbftpd.conf
15.7.1 系統(tǒng)區(qū)段
ServerName 定義服務(wù)器名稱
這個(gè)選項(xiàng)可以用來(lái)定義您的服務(wù)器名稱,當(dāng)使用者登入后將看到:
Connected to localhost.com.
220 Server Name FTP server (SmbFTPD Ver 0.9) ready.
Name (localhost:alex):
如果您沒(méi)有設(shè)定 ServerName,則 SmbFTPD 將顯示系統(tǒng)的 Hostname。
ServerName "Server Name" |
ListenOnAddress 設(shè)定要提供服務(wù)的 IP
當(dāng)使用 -D 模式 (standalone) 啟動(dòng) FTP 時(shí),您可以指定只接受連到這個(gè)地址的聯(lián)機(jī)。例如,假設(shè)您有二張網(wǎng)絡(luò)卡,一個(gè) IP 是 172.16.1.1,另一個(gè)是 61.62.63.64,您可以設(shè)定 ListenOnAddress 172.16.1.1 以表示只接受連到這個(gè) IP 的聯(lián)機(jī)。
如果您要接受所有聯(lián)機(jī),則請(qǐng)移除這個(gè)選項(xiàng)。
ListenOnAddress 192.168.0.1 |
Port 設(shè)定連接埠
當(dāng)使用 -D 模式 (standalone) 啟動(dòng) FTP 時(shí),您可以指定 SmbFTPD 所要使用的 Port。一般的 FTP port 為 21,您也可以使用 ftp 這個(gè)字符串表示,系統(tǒng)會(huì)自動(dòng)去 /etc/service 中查到相對(duì)的 port。
Port 21 |
Umask 設(shè)定新建檔案的權(quán)限
當(dāng)使用者建立檔案或目錄時(shí),所要使用的 umask。例如,您想要讓使用者新增檔案時(shí)的權(quán)限為 644,則設(shè) umask 為 022。詳細(xì)關(guān)于 umask 的設(shè)定請(qǐng) man 2 umask。這個(gè)選項(xiàng)的值必須為 8 進(jìn)位的數(shù)字,如 022、027 等。
Umask 022 |
PidFile 設(shè)定存放 Process ID 的檔案
這是您要存放 smbftpd pid 檔的地方,當(dāng)使用 daemon 模式時(shí),我們會(huì)將 smbftpd 的 process id 寫到這個(gè)檔案中。
PidFile /var/run/smbftpd.pid |
DebugMode 啟用除錯(cuò)模式
是否要用 syslog 記錄更多除錯(cuò)用的訊息。這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
DebugMode No |
LogCommand 記錄使用者執(zhí)行過(guò)的指令
是否要使用 syslog 的 LOG_FTP 記錄使用者執(zhí)行過(guò)的 FTP 指令。如果您將這個(gè)指令設(shè)為 Yes, 則使用者所執(zhí)行的 retrieve(get)、store(put)、append、delete、mkdir、rmdir、rename 等都會(huì)被記錄下來(lái),并用記錄該指令的文件名參數(shù)。在 FreeBSD 中,syslogd 會(huì)將這些記錄在 /var/log/xferlog 中。 這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
LogCommand No |
DoWtmpLog 記錄登入記錄
是否要將 ftp 聯(lián)機(jī)記錄在 /var/log/wtmp 中。這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
DoWtmpLog No |
DisableEPSV 停用指令 EPSV
是否要停用 EPSV 這個(gè)指令。如果您的服務(wù)器位于一些舊的防火墻后面,而一直無(wú)法聯(lián)機(jī),您可以設(shè)著停用 EPSV。這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
DisableEPSV No |
ShowSymlink 是否要顯示符號(hào)連結(jié)文件
當(dāng) ShowSymlink 為 No ,我們?cè)谑褂谜?ls 時(shí)不會(huì)列出 symbolic link 的檔案或目錄。這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
ShowSymlink No |
RestrictedPorts 禁止使用小于 1024 的埠號(hào)
當(dāng)這個(gè)選項(xiàng)設(shè)為 No 時(shí),smbftpd 將不檢查限制使用者使用的連結(jié)埠。我們預(yù)設(shè)限制使用者在使用 PORT 命令時(shí),只能使用 unprivileged ports (> 1024),不過(guò)這樣將違反 FTP protocol。
這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
RestrictedPorts Yes |
RestrictedDataPorts 限制數(shù)據(jù)聯(lián)機(jī)所使用的端口號(hào)
這個(gè)指令設(shè)成 NO 時(shí),smbftpd 將只使用 port 定義范圍在 IP_PORTRANGE_DEFAULT 的 port,而非 IP_PORTRANGE_HIGH 的 port。這個(gè)選項(xiàng)對(duì)于某些特殊的防火墻設(shè)定蠻有用的。請(qǐng) man 4 ip 以得到更多信息。
這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
RestrictedDataPorts Yes |
15.7.2 使用者登入控制
MaxConnection 設(shè)定最多聯(lián)機(jī)數(shù)目
這個(gè)選項(xiàng)可以讓您控制最多同時(shí)聯(lián)機(jī)的數(shù)量。如果 MaxConnection 大于 0,則在聯(lián)機(jī)數(shù)目到達(dá)您所設(shè)定的值時(shí),使用者就無(wú)法再登入。如果值為 0,則表示不做任何限制。
MaxConnection 30 |
RequireValidShell 登入的使用者是否要有合法 Sheel
當(dāng) RequireValidShell 為 Yes 時(shí),使用者必須有合法的 shell 才可以登入。合法的 shell 是以 getusershell(3) 這個(gè)函數(shù)取得,大多數(shù)的操作系統(tǒng)中,合法的 shell 都被定義在 /etc/shells 中。這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
RequireValidShell No |
EmptyPasswdLogin 是否允許空白密碼
是否允許空密碼的使用者登入。
這個(gè)選項(xiàng)的值可以是 Yes 或 No,默認(rèn)值為 No。
EmptyPasswdLogin No |
NoLoginList 設(shè)定禁止登入的使用者清單
設(shè)定您不想讓其登入的使用者,在 NoLoginList 中的使用者或群組不可以登入。
相關(guān)文章
Unix,BSD,Linux系統(tǒng)三者的區(qū)別小結(jié)
這篇文章主要介紹了Unix,BSD,Linux系統(tǒng)三者的區(qū)別小結(jié),需要的朋友可以參考下2023-05-03- 一些朋友問(wèn)小編FreeBSD如何添加硬盤?別擔(dān)心,今天小編就為大家分享FreeBSD添加硬盤的方法,希望對(duì)大家會(huì)有幫助,有需要的朋友一起去看看吧2017-04-06
- 今天小編為大家?guī)?lái)的是Freebsd PF 安裝使用詳解,希望對(duì)大家會(huì)有幫助,有需要的朋友一起去看看吧2017-04-06
FreeBSD下zfs: failed with error 6錯(cuò)誤如何解決?
最近一些朋友問(wèn)小編 FreeBSD下zfs: failed with error 6錯(cuò)誤如何解決?今天小編要為大家?guī)?lái)的是 FreeBSD下zfs: failed with error 6錯(cuò)誤的解決方法,有需要的朋友一起去看2017-04-06Unix文件系統(tǒng)和pwd命令實(shí)現(xiàn)詳解
今天小編要為大家?guī)?lái)的是Unix文件系統(tǒng)和pwd命令實(shí)現(xiàn)詳解,希望對(duì)大家會(huì)有幫助,有需要的朋友一起去看看吧2017-04-01- 今天小編將為大家?guī)?lái)的是Unix中的dot命令詳解!希望對(duì)大家會(huì)有幫助!有需要的朋友一起去看看吧2017-03-22
freebsd時(shí)間設(shè)置小節(jié)詳解
近日!一些朋友對(duì)于freebsd時(shí)間設(shè)置小節(jié)存在疑慮!下面小編將為大家?guī)?lái)的是freebsd時(shí)間設(shè)置小節(jié)詳解!希望對(duì)大家會(huì)有幫助!有需要的朋友一起去看看吧2017-03-19- 今天小編要為大家?guī)?lái)的是grub2引導(dǎo)freebsd詳解!希望對(duì)大家會(huì)有幫助,有需要的朋友一起去看看吧2017-03-19
- 下面小編為大家?guī)?lái)的是FreeBSD10安裝內(nèi)核源代碼方法講解!希望能夠幫助到大家!有需要的朋友一起去看看吧2017-03-19
FreeBSD下如何使GraphicsMagick支持中文字體?
最近一些朋友在問(wèn)FreeBSD下如何使GraphicsMagick支持中文字體?今天小編為大家?guī)?lái)的是FreeBSD下使GraphicsMagick支持中文字體的方法!有需要的朋友一起去看看吧2017-03-15