国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關(guān)注微信公眾號(hào)

利用OpenSSH建立自己的安全通道
2005-11-25   

眾所周知,使用互聯(lián)網(wǎng)絡(luò)的人越來(lái)越多,而Internet的安全問(wèn)題也越來(lái)越被人們所關(guān)注。在我們?nèi)粘J褂玫暮芏嗑W(wǎng)絡(luò)連接軟件并沒(méi)有提供必要的安全措施來(lái)防范,例如telnet,rlogin,ftp等等均在網(wǎng)絡(luò)中將用戶的密碼未加保護(hù)地傳輸,很多不懷好意的入侵者就這樣輕而易舉地得到您的帳戶密碼!
在這里我們介紹一下如何安全登錄,如何利用OpenSSH方便地建立自己的安全網(wǎng)絡(luò)通道。
1、OpenSSH簡(jiǎn)介
1.1 SSH協(xié)議
SSH的英文全稱為Secure Shell,是IETF(Internet Engineering Task Force)的Network Working Group所制定的一個(gè)協(xié)議,用于提供安全的遠(yuǎn)程登錄和其他安全網(wǎng)絡(luò)服務(wù)。
SSH協(xié)議目前版本號(hào)為2,還處于草案階段。不過(guò)由于網(wǎng)絡(luò)安全市場(chǎng)的強(qiáng)勁需求,已經(jīng)有許多公司和組織開(kāi)發(fā)了實(shí)用的基于SSH協(xié)議的軟件包。
其中最著名就是SSH Communication Security公司的SSH Secure Shell商用軟件包和OpenBSD Project開(kāi)放源碼組織開(kāi)發(fā)的OpenSSH軟件包,前者已經(jīng)在超過(guò)八十個(gè)國(guó)家擁有數(shù)百萬(wàn)用戶,后者也被難以數(shù)計(jì)的專業(yè)用戶和開(kāi)放源碼支持者廣泛使用。本文將只介紹基于OpenSSH的應(yīng)用技術(shù)。
1.2 什么是OpenSSH
如前文所述,OpenSSH是一個(gè)免費(fèi)(Free)版本的基于SSH協(xié)議的網(wǎng)絡(luò)連接工具軟件包。它將所有通信流量進(jìn)行加密,可以有效地防范各種監(jiān)聽(tīng)手段,杜絕網(wǎng)絡(luò)連接的泄密。OpenSSH具備安全性高、可靠性高、可用性好、功能全面等特點(diǎn)。不僅如此,由于OpenSSH的開(kāi)放性,用戶還可以通過(guò)Internet得到廣泛及時(shí)的技術(shù)支持。
OpenSSH目前支持支持SSH協(xié)議1.3版本、1.5版本和2.0版本,包括這樣一些應(yīng)用程序:
sshd:服務(wù)器端的守護(hù)程序,監(jiān)聽(tīng)來(lái)自客戶機(jī)的連接,負(fù)責(zé)完成安全驗(yàn)證并提供服務(wù)。
Ssh:客戶端程序,用于登錄到遠(yuǎn)程機(jī)器或執(zhí)行遠(yuǎn)程機(jī)器上的命令。
Scp:客戶端程序,可以安全地將文件拷貝到其他機(jī)器。
Ssh-keygen:密鑰管理程序,用來(lái)產(chǎn)生基于RSA或者DSA加密協(xié)議的密鑰對(duì),包括一個(gè)主機(jī)用公開(kāi)密鑰和一個(gè)客戶用私有密鑰。
Ssh-agent:安全驗(yàn)證的代理程序,用來(lái)管理本地密鑰實(shí)現(xiàn)自動(dòng)連接。
Ssh-add:與上面代理程序配合使用的應(yīng)用程序,可以將特定的密鑰加入到代理程序的管理之中。
Sftp-server:安全文件傳輸?shù)姆?wù)程序。
Sftp:安全文件傳輸?shù)目蛻舫绦颍梢耘c運(yùn)行sftp-server 的機(jī)器建立ftp連接。
Ssh-keyscan:一個(gè)用來(lái)搜集主機(jī)公用密鑰的工具程序,效率很高。
1.3 你自己的OpenSSH
想擁有自己的OpenSSH?那好…
首先,我們來(lái)了解如何得到OpenSSH軟件包。通常情況下,你所安裝的Linux系統(tǒng)會(huì)自動(dòng)配置,比如RedHat 7.0,Mandrake 8.0等。如果想自己安裝,或者想得到最新的版本,即使你的機(jī)器上還沒(méi)有安裝也不要緊,可以到OpenSSH的官方網(wǎng)站www.openssh.org去自行下載,目前的最新版本是2001年5月發(fā)布的OpenSSH 2.9。你可以在網(wǎng)頁(yè)http://www.openssh.com/portable.html上選擇離自己最近的站點(diǎn)下載。
接下來(lái)自然就是安裝,如果你下載了rpm程序包,那么可以使用如下命令來(lái)安裝,這里假定你擁有最新的2.9版本。
[jack@mypc download]$ rpm -i openssh-2.9p2-1.i386.rpm
如果你下載的是源程序包,那么可以先解壓縮該包,然后進(jìn)入openssh-2.9p2目錄來(lái)安裝。
[jack@mypc download]$ tar -vxzf openssh-2.9p2.tar.gz
[jack@mypc openssh-2.9p2]$ cd openssh-2.9p2
[jack@mypc openssh-2.9p2]$ ./configure
[jack@mypc openssh-2.9p2]$ make
[jack@mypc openssh-2.9p2]$ make install
現(xiàn)在你已經(jīng)有了自己的OpenSSH包,讓我們一起來(lái)進(jìn)入主題,看看如何利用它來(lái)快速的建立起自己的安全通道吧。
2、用ssh構(gòu)建安全通道
2.1 ssh的端口轉(zhuǎn)發(fā)功能
前文已經(jīng)介紹,ssh是OpenSSH包中的一個(gè)重要應(yīng)用程序,它功能非常強(qiáng)大,不僅可以象普通telnet用戶一樣地登錄遠(yuǎn)程的主機(jī),還可以指令主機(jī)去執(zhí)行特定的命令以完成特定的任務(wù)。當(dāng)然,這些操作是在得到主機(jī)的安全驗(yàn)證之后,并且此后的所有網(wǎng)絡(luò)通訊均被ssh加密傳輸,安全可靠。
Ssh還有一個(gè)很有用的端口轉(zhuǎn)發(fā)功能,它能夠?qū)CP 連接通過(guò)ssh的安全機(jī)制轉(zhuǎn)發(fā)到遠(yuǎn)程機(jī)器上,這樣我們就可以得到一個(gè)可靠的TCP會(huì)話,從而實(shí)現(xiàn)安全的信息通道。
Ssh端口轉(zhuǎn)發(fā)的典型命令格式如下:
ssh -L 4001:localhost:4011 jack@myserver.com
-L選項(xiàng)指示將要被轉(zhuǎn)發(fā)的端口對(duì);4001:localhost:4011參數(shù)表示本地端口4001將被轉(zhuǎn)發(fā)到遠(yuǎn)端的4011端口(需要注意的是這里localhost指示的是遠(yuǎn)程主機(jī)的名字或者IP地址,它是被遠(yuǎn)程機(jī)器所能解釋的名字,在本例中遠(yuǎn)程主機(jī)是myserver.com,而localhost則是指myserver.com本身);jack@myserver.com參數(shù)指明ssh通道將連接到myserver.com上,并且使用用戶jack所擁有的公用密鑰來(lái)進(jìn)行身份驗(yàn)證。 
2.2 針對(duì)安全通道來(lái)配置OpenSSH
要正確地使用OpenSSH的端口轉(zhuǎn)發(fā)功能,必須了解其基本的配置方法。
第一步,要產(chǎn)生正確的密鑰對(duì),并將公用密鑰配置到遠(yuǎn)程主機(jī)的相應(yīng)位置。以前面提供的典型命令來(lái)說(shuō),如果我們假定本地用戶名也是jack,那么密鑰操作如下:
(1)產(chǎn)生密鑰對(duì)。在本地主機(jī)上使用命令ssh-keygen來(lái)產(chǎn)生新的密鑰對(duì),默認(rèn)密鑰類型是版本1的rsa1密鑰,其文件名為identity和identity.pub,保存在當(dāng)前用戶的主目錄下的.ssh目錄中,即~/.ssh/。(關(guān)于ssh-keygen的用法請(qǐng)用man ssh-keygen查看使用手冊(cè),而~則代表/home/jack,用戶jack的主目錄)
(2)拷貝公用密鑰到遠(yuǎn)程主機(jī)。將密鑰identity.pub拷貝到遠(yuǎn)程主機(jī)上用戶jack的主目錄下的.ssh目錄中,導(dǎo)入到文件authorized_keys中。由于密鑰文件是文本格式,可以用命令cat identity.pub >> authtorized_keys來(lái)將新的公用密鑰添加到該文件尾部。注意:遠(yuǎn)程主機(jī)在對(duì)密鑰的認(rèn)證時(shí)只讀取authorized_keys,而并不檢查identity.pub文件,所以導(dǎo)入后可以將之刪除。
至于版本2的密鑰操作方式與此完全相同,只是新的密鑰文件名分別為id_rsa和id_dsa,公用密鑰文件分別為id_rsa.pub和id_dsa.pub 。
第二步,本地ssh客戶機(jī)的配置文件主要是/etc/ssh_config和~/.ssh/config文件,使用端口轉(zhuǎn)發(fā)無(wú)需對(duì)此做特別配置,采用默認(rèn)值即可。在遠(yuǎn)程ssh服務(wù)器上,其配置文件為/etc/sshd_config,也不用做特別修改。了解配置的具體細(xì)節(jié),可以用man ssh和man sshd命令來(lái)查看聯(lián)機(jī)使用手冊(cè)。
3、使用安全通道的程序示例
3.1 示例程序環(huán)境
遠(yuǎn)程主機(jī):myserver.com (192.1.0.99)
本地主機(jī):mypc (192.1.0.3)
遠(yuǎn)程帳戶:jack
本地帳戶:jack
操作系統(tǒng):Mandrake Linux 8.0
編譯系統(tǒng):gcc 2.96
3.2 用ssh命令建立SSH通道
[jack@mypc sshtest]$ ssh -L 4001:localhost:4017 jack@myserver.com
Last login: Tue Aug 7 19:05:10 from 192.1.0.3
3.3 本地程序清單(sshcall.c)
#include
#include
#include
#include
#include
int main(int argc, char *argv[])
{
int fd;
struct sockaddr_in address;
int address_len;
int rtval;
char server_ip[20]="127.0.0.1";
short int port = 4001;
char sendbuf[100];
char recvbuf[100];
int len;
/* 創(chuàng)建套接字句柄 */
fd = socket(PF_INET, SOCK_STREAM, 0);
/* 配置將要連接的socket到本地端口4001 */
address.sin_family = PF_INET;
address.sin_addr.s_addr = inet_addr(server_ip);
address.sin_port = htons(port);
address_len = sizeof(address);
/* 嘗試連接到遠(yuǎn)程端口,實(shí)際上通過(guò)了SSH的轉(zhuǎn)發(fā) */
rtval = connect(fd, (struct sockaddr *)&address, address_len);
if(rtval == -1) exit(1);
/* 發(fā)送一個(gè)字符串 */
strcpy(sendbuf, "Hello! Server.");
send(fd, sendbuf, strlen(sendbuf), 0);
printf("\nData send out!");
/* 等待服務(wù)器應(yīng)答 */
len = recv(fd, recvbuf, 100, 0);
printf("\nData from server: %s", recvbuf);
/* 再等待服務(wù)器的另一個(gè)字符串 */
len = recv(fd, recvbuf, 100, 0);
printf("\nData from server: %s", recvbuf);
/* 關(guān)閉socket */
close(fd);
return 0;
}
3.4 遠(yuǎn)程服務(wù)程序清單(sshlisten.c)
#include
#include
#include
#include
int main(int argc, char* argv[])
{
int fd;
int address_len;
struct sockaddr_in address;
/* 創(chuàng)建套接字句柄 */
fd = socket(PF_INET, SOCK_STREAM, 0);
/* 配置socket到本地4011端口 */
address.sin_family = PF_INET;
address.sin_addr.s_addr = htonl(INADDR_LOOPBACK);
address.sin_port = htons(4011);
address_len = sizeof(address);
bind(fd, (struct sockaddr *)&address, address_len);
/* 監(jiān)聽(tīng)端口并只允許一個(gè)連接在監(jiān)聽(tīng)隊(duì)列中 */
listen(fd, 5);
while(1)
{
struct sockaddr_in client_address;
int len,datalen;
int client_sockfd;
char *answer = "OK";
char *answer_quit = "QUIT";
char *client_end = "END";
char data[100];
char *client_ip;
printf("waiting...");
fflush(stdout);
/* 等待客戶機(jī)的連接 */
len = sizeof(client_address);
client_sockfd = accept(fd, (struct sockaddr *)&client_address,
(int *)&len);
/* 打印出實(shí)際連接在服務(wù)器上所看到的網(wǎng)絡(luò)地址及端口 */
client_ip = inet_ntoa(client_address.sin_addr);
printf("\nClient IP address is %s, on port %d.",client_ip,
(int)client_address.sin_port);
/* 從客戶機(jī)讀取數(shù)據(jù) */
datalen = recv(client_sockfd, data, 100, 0);
if(datalen > 0) data[datalen] = '\0';
printf("\nClient data is: %s", data);
/* 連續(xù)發(fā)送兩個(gè)字符串 */
send(client_sockfd, answer, strlen(answer), 0);
send(client_sockfd, answer_quit, strlen(answer_quit), 0);
/* 關(guān)閉socket,結(jié)束這個(gè)連接 */
close(client_sockfd);
printf("\n");
}
return 0;
}
3.5 應(yīng)用示例說(shuō)明
將上述兩個(gè)程序例子分別在客戶機(jī)和服務(wù)器上運(yùn)行,sshlisten在遠(yuǎn)程服務(wù)器端運(yùn)行,sshcall在客戶端運(yùn)行,讀者可以自行驗(yàn)證結(jié)果。注意觀察在服務(wù)器上sshlisten輸出的連接信息,以加深對(duì)端口轉(zhuǎn)發(fā)的理解。
4、OpenSSH資源
OpenSSH的rpm下載:
ftp://ftp.openbsd.org/pub/OpenBSD/OpenSSH/portable/rpm/RH71/
openssh-2.9p2-1.i386.rpm
openssh-askpass-2.9p2-1.i386.rpm
openssh-askpass-gnome-2.9p2-1.i386.rpm
openssh-clients-2.9p2-1.i386.rpm
openssh-server-2.9p2-1.i386.rpm
OpenSSH的源程序下載:
ftp://ftp.openbsd.org/pub/OpenBSD/OpenSSH/portable/
openssh-2.9p2.tar.gz
README
INSTALL
TODO
UPGRADING
OpenSSH的使用手冊(cè)查閱:http://www.openssh.com/manual.html
SSH基本協(xié)議的資源(可以在www.ietf.org網(wǎng)站查詢""關(guān)鍵字得到更多):
1. SSH Protocol Architecture
http://search.ietf.org/internet-drafts/draft-ietf-secsh-architecture-09.txt
2. SSH Authentication Protocol
http://search.ietf.org/internet-drafts/draft-ietf-secsh-userauth-11.txt
3. SSH Connection Protocol
http://search.ietf.org/internet-drafts/draft-ietf-secsh-connect-11.txt
4. SSH Transport Layer Protocol
http://search.ietf.org/internet-drafts/draft-ietf-secsh-transport-09.txt

熱詞搜索:

上一篇:編譯安裝openssh,使用RSA登陸
下一篇:利用SecureCRT產(chǎn)生的密鑰對(duì)連接SSH服務(wù)器

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
欧美日韩另类一区| 欧美日韩国内| 欧美日韩精品免费观看视一区二区 | 久久精品主播| 欧美成人免费全部| 国产视频精品免费播放| 亚洲午夜视频在线观看| 国产在线拍偷自揄拍精品| 亚洲高清视频一区| 亚洲一区二区三区四区中文| 久久久一区二区三区| 欧美精品国产精品日韩精品| 国产精品试看| 日韩午夜免费视频| 欧美不卡视频一区| 国产欧美日韩一区二区三区在线观看| 亚洲大片一区二区三区| 欧美一区二区三区播放老司机| 欧美精品偷拍| 伊人一区二区三区久久精品| 午夜精品影院| 国产精品久久久久国产精品日日| 亚洲国产婷婷综合在线精品| 久久av资源网站| 国产精品免费小视频| 99精品国产福利在线观看免费| 久久久五月婷婷| 国产精品高清免费在线观看| 亚洲黄色小视频| 久久久久久久成人| 国产亚洲视频在线| 久久精品免视看| 国产日韩精品一区二区| 亚洲中字在线| 国产精品免费视频观看| 亚洲一级网站| 国产精品丝袜91| 午夜一区二区三区不卡视频| 国产精品久久久一区二区三区| 一区二区三区www| 国产精品久久久久久久久搜平片 | 久久在线视频| 亚洲精品麻豆| 亚洲国产精品ⅴa在线观看 | 欧美日韩一区二区三区在线视频| 激情成人av| 狠狠色噜噜狠狠色综合久| 欧美影院成人| 国内成+人亚洲| 久久久久久久综合色一本| 一区二区自拍| 欧美日韩亚洲精品内裤| 亚洲一区在线直播| 激情成人av在线| 欧美fxxxxxx另类| 一区二区三区黄色| 国内精品国产成人| 欧美另类videos死尸| 亚洲欧美日韩专区| 亚洲国产激情| 国产精品欧美风情| 裸体素人女欧美日韩| 亚洲卡通欧美制服中文| 国产乱码精品| 欧美精品一区二区视频| 午夜视频在线观看一区二区| 在线观看视频日韩| 国产精品欧美久久久久无广告| 久久国产精品一区二区| 日韩视频在线播放| 国内精品国语自产拍在线观看| 欧美另类一区二区三区| 久久久999精品| 在线亚洲观看| 一区在线视频| 国产精品久久久久久影院8一贰佰| 久久久久久久一区二区三区| 99视频一区二区三区| 黄色日韩网站视频| 国产精品视频一二| 欧美精品福利视频| 久久人人爽爽爽人久久久| 亚洲婷婷在线| 日韩一级精品| 最近看过的日韩成人| 国产一区成人| 国产精品人人做人人爽 | 韩国女主播一区| 欧美日韩另类一区| 免费不卡欧美自拍视频| 午夜在线视频一区二区区别| 在线视频欧美精品| 亚洲国产精品电影| 伊人夜夜躁av伊人久久| 国产精品视频免费在线观看| 欧美视频中文一区二区三区在线观看 | 在线观看日韩www视频免费| 午夜欧美大尺度福利影院在线看| 久久亚洲欧美| 免费日韩av电影| 亚洲麻豆国产自偷在线| 伊人狠狠色j香婷婷综合| 国产精品国内视频| 欧美日韩在线一区二区| 欧美精选午夜久久久乱码6080| 免费成人av在线| 另类av一区二区| 免费人成网站在线观看欧美高清 | 欧美日韩精品一区二区三区四区 | 欧美高清视频| 欧美激情免费在线| 欧美喷水视频| 欧美私人啪啪vps| 国产精品免费观看在线| 国产精品永久免费在线| 国产欧美日韩在线| 国产自产精品| 亚洲电影专区| 亚洲精品日韩在线观看| 一本到高清视频免费精品| 亚洲天堂网在线观看| 亚洲欧美日韩在线一区| 久久不射网站| 欧美国产日韩a欧美在线观看| 欧美日韩视频一区二区| 国产精品青草综合久久久久99| 国产视频综合在线| 亚洲人精品午夜| 亚洲与欧洲av电影| 久久精品中文| 欧美日韩国产首页在线观看| 国产精品视频午夜| 亚洲国产精品一区二区三区| 制服丝袜激情欧洲亚洲| 亚洲国产精品va在线看黑人| 伊人色综合久久天天| 最新高清无码专区| 国产精品久久久久久久久| 欧美精品麻豆| 欧美一区二区成人6969| 国产日韩欧美综合| 亚洲高清一区二| 午夜日韩在线| 一区免费视频| 精品成人一区二区| 亚洲欧洲一区二区三区在线观看| 欧美一区二区三区在线观看| 欧美久久在线| 国产一区二区精品久久99| 亚洲国产精品一区制服丝袜| 国产精品99久久久久久白浆小说| 欧美中文日韩| 欧美日韩精品欧美日韩精品| 国内综合精品午夜久久资源| 日韩视频在线观看| 欧美在线免费观看视频| 欧美日本一道本| 亚洲国产欧美一区| 久久免费视频在线| 国产精品人人做人人爽人人添| 亚洲精品久久久久久久久| 久久琪琪电影院| 国产九区一区在线| 亚洲天堂激情| 欧美日本中文字幕| 亚洲精品色婷婷福利天堂| 午夜精品999| 国产精品亚洲不卡a| 亚洲香蕉视频| 国产精品久久久久久五月尺| 99综合视频| 欧美日韩亚洲综合| aa级大片欧美三级| 欧美日韩亚洲一区二区三区在线 | 欧美freesex8一10精品| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲欧美资源在线| 国产精品网站在线播放| 亚洲一区在线视频| 国产精品日本一区二区| 亚洲一区二区动漫| 国产精品人人做人人爽人人添| 亚洲一区二区三区国产| 国产精品乱人伦中文| 亚洲永久在线观看| 国产日产高清欧美一区二区三区| 亚洲欧美在线免费观看| 国产精品网站在线观看| 欧美一区激情| 一区在线影院| 久久亚洲私人国产精品va媚药| 国模精品娜娜一二三区| 亚洲制服欧美中文字幕中文字幕| 亚洲网站视频| 国产农村妇女精品一二区| 欧美激情综合五月色丁香小说| 狠狠色综合色区| 亚洲综合日韩中文字幕v在线| 国产精品久久久久影院亚瑟| 国产亚洲精品久久久久久|