SSH與OpenSSH
傳統的網絡服務程序,如:ftp、pop和telnet在本質上都是不安全的,因為它們在網絡上用明文傳送口令和數據,別有用心的人非常容易就可以截獲這些口令和數據。而且,這些服務程序的安全驗證方式也是有其弱點的,就是很容易受到“中間人”(man-in-the-middle)這種方式的攻擊。所謂“中間人”的攻擊方式,就是“中間人”冒充真正的服務器接收你的傳給服務器的數據,然后再冒充你把數據傳給真正的服務器。服務器和你之間的數據傳送被“中間人”一轉手做了手腳之后,就會出現很嚴重的問題。
SSH的英文全稱是Secure SHell。通過使用SSH,你可以把所有傳輸的數據進行加密,這樣“中間人”這種攻擊方式就不可能實現了,而且也能夠防止DNS和IP欺騙。還有一個額外的好處就是傳輸的數據是經過壓縮的,所以可以加快傳輸的速度。SSH有很多功能,它既可以代替telnet,又可以為ftp、pop、甚至ppp提供一個安全的“通道”。
最初SSH是由芬蘭的一家公司開發的。但是因為受版權和加密算法的限制,現在很多人都轉而使用OpenSSH。OpenSSH是SSH的替代軟件,而且是免費的,可以預計將來會有越來越多的人使用它而不是SSH。
SSH是由客戶端和服務端的軟件組成的,有兩個不兼容的版本分別是:1.x和2.x。用SSH 2.x的客戶程序是不能連接到SSH 1.x的服務程序上去的。OpenSSH 2.x同時支持SSH 1.x和2.x。
SSH的安全驗證是如何工作的
從客戶端來看,SSH提供兩種級別的安全驗證。
第一種級別(基于口令的安全驗證)只要你知道自己帳號和口令,就可以登錄到遠程主機。所有傳輸的數據都會被加密,但是不能保證你正在連接的服務器就是你想連接的服務器。可能會有別的服務器在冒充真正的服務器,也就是受到“中間人”這種方式的攻擊。
第二種級別(基于密匙的安全驗證)需要依靠密匙,也就是你必須為自己創建一對密匙,并把公用密匙放在需要訪問的服務器上。如果你要連接到SSH服務器上,客戶端軟件就會向服務器發出請求,請求用你的密匙進行安全驗證。服務器收到請求之后,先在你在該服務器的家目錄下尋找你的公用密匙,然后把它和你發送過來的公用密匙進行比較。如果兩個密匙一致,服務器就用公用密匙加密“質詢”(challenge)并把它發送給客戶端軟件。客戶端軟件收到“質詢”之后就可以用你的私人密匙解密再把它發送給服務器。
用這種方式,你必須知道自己密匙的口令。但是,與第一種級別相比,第二種級別不需要在網絡上傳送口令。
第二種級別不僅加密所有傳送的數據,而且“中間人”這種攻擊方式也是不可能的(因為他沒有你的私人密匙)。但是整個登錄的過程可能需要10秒。
Windows下的OpenSSH解決方案
可以看到,SSH具備很多優勢,因此很多現代Linux服務器基于安全考慮已經不再開放傳統的telnet和ftp服務,而是采用更安全SSH和sftp。隨Linux越來越多的進入服務器領域,這種情況也越來越常見。從安全角度上來看這當然是個進步,不過也帶來了新的問題。因為目前用來提供SSH相關服務的OpenSSH主要在Linux環境開發的,為了讓采用windows平臺的客戶機與Linux服務器上的OpenSSH服務器通信,我們有必要尋找一個OpenSSH的windows解決方案。當然,基于SSH的眾多安全特性,讓windows服務器可以運行SSH相關服務也是個誘人的想法。為此,尋找windows平臺下的SSH解決方案成為很多網管的目標。
這里,首先納入考慮的還是OpenSSH的for windows版本。畢竟,OpenSSH幾乎是現在SSH實現的代名詞,與現有各種SSH服務器和客戶端的兼容性非常良好。我曾經遇到過其它一些支持SSH的客戶端工具生成的密匙無法被SSH服務器識別的情況,在我更換了OpenSSH的密匙生成工具重新生成密匙后解決了問題。在本文中,我們將主要介紹windows平臺的OpenSSH工具的使用。OpenSSH for windows實際上是Cygwin系列安裝包中的OpenSSH安裝包,它在無需安裝整個Cygwin安裝包的情況下安裝OpenSSH所需的最小工具集。
小知識:什么是Cygwin
Cygwin是Windows下的一個Linux仿真環境,它包括兩部分,一是cygwin1.dll文件,它作為一個Linux API仿真器層為各Linux應用程序提供各種Linux下的系統調用。另一部分包括一系列Linux下的常用工具包,這些工具包是用l這些工具的源碼針對Cygwin環境重慶編譯而成,本文介紹的OpenSSH for windows就是這些工具包中的一個。需要注意的是Cygwin并不能讓原生Linux程序在windows下直接運行,如果你想讓一個Linux應用程序在windows下運行,你將不行不將應用程序從源代碼重新編譯。
不過OpenSSH for windows是一個命令行的工具,而且目前與windows 2003的兼容性還不是很好。其它還有一些windows平臺的OpenSSH替代品,下面我主要介紹幾種免費的產品。
PuTTY是這些產品中最有名的一種,它實際包含了多個工具分別用來完成SSH的各個功能,包括了SSH1和SSH2的客戶端和服務器端實現。它采用類似類似BSD的MIT軟件許可證。它也主要是一個基于命令行的工具。
WinSCP是一個Windows環境下使用SSH的開源圖形化SFTP客戶端。同時支持SCP協議。它的主要功能就是在本地與遠程計算機間安全的復制文件。它的最大特點是界面非常友好,使用時可以選擇windows資源管理器界面或者“Norton Commander”界面,而且已經有中文版本。可惜,在我的windows XP機器上,安裝始終報錯。
Secure iXplorer GPL是PuTTY'工具包中pscp.exe(用于安全復制文件)的一個圖形化前端。
FileZilla是一款windows平臺下的功能強大的FTP客戶端軟件,它有豐富的功能特性,并支持SFTP。