一、SSH客户端之SSH Secure Shell 的连接方法
1、运行环境
WINDOWS下安装SSH客户端,名字是SSHSecureShellClient-3.2.9.exe,可以到http://www.ssh.com/下载,当然了,在SERVER端我们也可以安装Openssh,但此文章着重介绍的是ssh的技术,所以我们使用的是http://www.ssh.com/ for UNIX/LINUX 的SERVER 端,现在最新版本是ssh-3.2.9-1.i386.rpm(如果你是AIX或者SOLARIS,要下不同的版本,这里以RHCE3为例子)。确定把UNIX类主机的默认的Openssh全部卸载掉后安装ssh-3.2.9-1.i386.rpm。
2、为什么要公私钥认证方法(连接到主机不输入密码)
我们需要知道Publick Key是指公钥,而private key是指私钥。认证的过程是这样的:public key对数据进行加密而且只能用于加密,private key只能对所匹配的public key加密过的数据进行解密。我们把public key放在远程系统合适的位置,然后从本地开始进行ssh连接。此时,远程的sshd会产生一个随机数并用我们产生的public key进行加密后发给本地,本地会用private key进行解密并把这个随机数发回给远程系统。最后,远程系统的sshd会得出结论——我们拥有匹配的private key允许我们登录。就这么简单!
3、在本机生成密钥过程
WINDOWS下寻找ssh-keygen2.exe文件,这是生成密钥的文件,我的在C:\Program Files\SSH Communications Security\SSH Secure Shell,在DOS下执行这个文件,方法是
C:\Program Files\SSH Communications Security\SSH Secure Shell> ssh-keygen2 -t rsa
我用的是rsa的密钥,默认是2048位,足够我们用的了,还可以使用dsa方式的密钥。我就不在这里说明了
系统自动生成密钥对,默认放在C:\Documents and Settings\XXX\Application Data\SSH\UserKeys目录下,其中XXX是你执行程序时用的帐户,默认名称是id_rsa_2048_a和id_rsa_2048_a.pub,而后者就是我们要传到服务器上的公钥。(生成密钥对的同时让你输入一个密码,因为我们想不输入密码直接登陆服务器,所以就直接回车了,但如果你想更安全一些,还是建议你在这里也输入密码。)
4、用SSH客户端从本机登陆到远程UNIX类服务器上
我们还按以前的方法登陆到远程UNIX类服务器上,这样登陆后我们会在用户目录下,PWD一下,你可以看到你的用户目录路径,比如我的就是/home/test,那么好了,我们建立一个.ssh2的文件夹,在里面建立一个文件,authorization,内容如下:
key id_rsa_2048_a.pub
然后把你WINDOWS客户端上的id_rsa_2048_a.pub上传到你在UNIX类服务器上刚建立好的.ssh2文件夹下,关闭SSH客户端。
5、用SSH客户端公钥认证状态登陆
重新启动SSH客户端,在登陆认证状态栏选择Public Key方式,登陆到你刚才放id_rsa_2048_a.pub的那台服务器,你会发现你马上就登陆进来了,没有密码限制了。这个时候用公私钥认证和用密码认证同时存在,还没有达到我们的要求,那我们就在UNIX类服务器上修改/etc/ssh2/sshd2_config文件
把以下如下三行的password 删除,下面这三行是修改好的
AllowedAuthentications publickey
AllowedAuthentications hostbased,publickey
RequiredAuthentications publickey
这样当你再用密码登陆的时候就出现如下对话框了!!
初学vb 回复于:2005-01-07 11:56:35 |
第二章是关于PUTTY客户端使用的认证方法,第三章是关于SSH服务器端安装的注意事项,第四章是SSH服务器的配置及安全!! |
初学vb 回复于:2005-01-07 16:31:32 |
第二章 SSH客户端之Putty的连接方法 1、运行环境 WINDOWS下安装的SSH客户端,名字是putty-0.56-installer.exe,可以到如下地址下载: http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html,这个安装包是所有工具的集合,其实如果只做为连接用,你可以只下putty0.56.exe的。但我们这里因为要做密钥对,所以就下整个包安装吧。 2、在本机生成密钥过程 用putty套装的puttygen来产生密钥。密钥的类型选择SSH2 RSA。密钥的位数选择2048,然后点击"Generator",此时密钥生成当然也有几个选项出现。如果你有不止一个key,你可以在“Key comment”作注释用于区别其他的key。“Key passphrase“和“Confirm passphrase“用于对硬盘上的key进行加密,如过你自己一个人用机器觉得安全有保障的话可以让它们为空。然后保存两个key,用默认方式保存,那么公钥你可以指定文件名,私钥默认的文件扩展名是.ppk。在这里我们命名它为test.ppk,而公钥我们保存为test.pub,需要注意的是,如果用putty连接,私钥的扩展名必须是.ppk,而且你还可以将这个.ppk的私钥保存为SSH Secure Shell 格式和Openssh格式认知的私钥,这个对两个UNIX类主机之间相互通信提供了很大帮助。(我们以后会将两个UNIX类主机通过公私钥认证的方法给大家讲讲) 4、用Putty从本机登陆到远程UNIX类服务器上 我们还按先前的方法登陆到远程UNIX类服务器上,这样登陆后我们会在用户目录下,PWD一下,你可以看到你的用户目录路径,比如我的就是/home/test,那么好了,我们建立一个.ssh2的文件夹,在里面建立一个文件,authorization,内容如下: key test.pub 然后把你WINDOWS客户端上的test.pub上传到你在UNIX类服务器上刚建立好的.ssh2文件夹下,关闭Putty。这个上传命令你可以用 put ,下载就用get。你的通道可以用PSFTP建立,这个也在PUTTY的组件中。 5、用SSH客户端公钥认证状态登陆 重新启动Putty,建立一个session命名为test,设定你要登陆的远程ip,协议设为ssh,Connection设定在ssh的auth选项中,将private key的文件选择为刚才我们由puttygen产生的密钥test.ppk。点Open,要求输入username,我们输入用户名后远程系统开始public key认证,如果密钥有passphrase 则需要输入,否则直接就登录了。这个时候用公私钥认证和用密码认证同时存在,还没有达到我们的要求,那我们就在UNIX类服务器上修改/etc/ssh2/sshd2_config文件 把以下如下三行的password 删除,下面这三行是修改好的 AllowedAuthentications publickey AllowedAuthentications hostbased,publickey RequiredAuthentications publickey 这样当你再用密码登陆的时候就出现如下对话框了!! |
初学vb 回复于:2005-01-07 16:32:50 |
最后那个对话框是你被远程主机拒绝的对话框,贴图贴不上,就写了! |
初学vb 回复于:2005-01-07 16:39:17 |
三\四章明天奉上,希望能对大家有所帮助,欢迎转载,请注明是人来疯技术文档!!谢谢!!也欢迎大家2月能到人来疯论坛坐坐,www.d-1701.com |
初学vb 回复于:2005-01-08 14:34:38 |
第三章 Ssh服务器端安装 1、环境: 因为我们选用的SSH服务器是http://www.ssh.com 的SSH Secure Shell for unix类产品,所以我们主要介绍一下此类的Ssh服务器的安装过程。(SSH有两个版本,我们现在介绍的是版本2;Openssh就不介绍了,大家有兴趣的话可以参考一下网上文章) 2、编译安装 我们前面介绍过,现在的Ssh server for unix 类的最新版本是ssh-3.2.9-1,我建议大家用官方提供的TAR包,当然,如果你不熟悉编译过程,用RPM等安装方式也是可以的。如果用RPM安装,请先下载ssh-3.2.9-1.i386.rpm , 大家可以到以下地址下载: http://ftp.ssh.com/priv/secureshell/329wks+srv-lt49ldrk/linux/ssh-3.2.9-1.i386.rpm 安装时请用管理员权限 # rpm –ivh ssh-3.2.9-1.i386.rpm 如果是升级安装那参数就用 –Uvh 而3.2.9-1的TAR包大家可以到http://downloads.planetmirror.com/pub/ssh/ssh-3.2.9.1.tar.gz下载。安装时也使用管理员权限: # tar xzvf ssh-3.2.9.1.tar.gz # cd ssh-3.2.9.1 # ./configure (这里我们要说明一下,原来有些文档写如果你希望用tcp_wrappers来控制SSH,那么在configure时需要加上选项“--with-libwrap=/path/to/libwrap/”, 用来告诉SSH关于libwrap.a 和tcpd.h的位置,但3.2.0以上的SSH已经不需要这么麻烦了,它们已经内置了控制访问权限的功能。) # make ; make install ; make clean 这样就结束了安装。 3、简单配置Ssh server 无论你是用RPM或TAR包安装的ssh server,它的配置文件都在/etc/ssh2/sshd2_config,安装完后一般不用配置它,但如果你的22端口在安装ssh server之前已经被其他程序占用,那么你需要简单的配置一下这个文件,执行 vi /etc/ssh2/sshd2_config,找到第27行,Port 22 ,把22改成其他的端口就可以了。 4、启动Ssh server Ssh server 的默认启动文件是/usr/local/sbin/sshd2,而安装程序自动做了一个连接到这个文件的名字为sshd的文件,我们只要在/usr/local/sbin/目录中执行 ./sshd & 就可以简单的启用Ssh server,然后我们执行 # netstat –na 会看见22端口已经被监听了(你的可能是其他端口,具体看你在sshd2_config文件中的设置了。)但我们不想每次都要手动启动Ssh server,那么我们可以修改一下/etc/rc.d/rc.local文件,在这个文件的最后加入以下内容: #start ssh /usr/local/sbin/sshd & 其中第一行为注释内容,第二行为启动SSH服务器并作为后台守护进程运行。 这样就好了,系统重起时可以自动启动SSH服务,但是启动后你如果在服务器端插上显示器,会在最后该登陆的时候看到一行字,意思就是Ssh server 服务启动了,我比较挑剔,不想看到这个提示,而且我想把Ssh服务放到LINUX服务启动过程中,这样比较美观一点。那么我们就不能修改/etc/rc.d/rc.local文件,我们要进入/etc/init.d/中建立一个SHELL文件,名字就叫sshd 内容如下: #!/bin/bash cd /usr/local/sbin ./sshd & 然后给这个文件加上可执行权限 # chmod +x sshd 然后进入/etc/rc3.d,做一个软链接文件 # cd /etc/rc3.d # ln -s ../init.d/sshd S13sshd 这样就达到了我的要求,好了,Ssh server的安装就介绍到这里吧,安装是很简单的,希望大家编译安装成功。 |
初学vb 回复于:2005-01-08 14:38:51 |
其实安装应该是在应用之前的,而本来我想写的就是不用密码的登陆方法,后来发现大家对安全的认知度不是很高,至今还有人用TELNET登陆,所以索性我就写了这么一个普及系列文章,大家能在这里找到一丁点有用的地方我就满足了! |
forestwill 回复于:2005-01-08 23:31:51 |
好东西,顶,小弟正需要这样的教程,非常感谢楼主 |
ouatitj 回复于:2005-01-08 23:51:17 |
不错 不过 楼主能不能告诉偶SSH是什么东东 是不是一种验证的方法 ? |
yjnet 回复于:2005-01-10 08:13:57 |
ssh是一种安全shell,可确保你在远程能安全登录服务器。它是用来取代不安全的r*命令的。它还可通过端口转发功能保护X window等程序的安全传输。 下面有ssh权威指南一书的读书笔记: http://www.ringkee.com/jims/read_folder/ |
jyhuang 回复于:2005-01-10 09:29:48 |
四章??? |
初学vb 回复于:2005-01-10 10:53:57 |
由于周六日在公司加班,第四章还没完成,我尽量在今天写完奉献给大家!! |
初学vb 回复于:2005-01-10 23:54:08 |
越写越多,我把WIN下的SSH也加进来了,把原来的结构完全打乱重来,而且现在碰到一个问题,就是两边的服务器都是UNIX类时的认证方法,理论上可行,实际操作有问题,请大家耐心等等,毕竟大家需要的是指导性文章,而不是误导!!相信我,等待是有价值的!! |
samme 回复于:2005-01-11 01:02:08 |
[quote:7d8d296ad8="初学vb"]越写越多,我把WIN下的SSH也加进来了,把原来的结构完全打乱重来,而且现在碰到一个问题,就是两边的服务器都是UNIX类时的认证方法,理论上可行,实际操作有问题,请大家耐心等等,毕竟大家需要的是指导性文章,而不是误导!!?..........[/quote:7d8d296ad8] 请楼上说的明白些,我真的是不明白两台unix的机子相互认证会出来什么问题?(我是天天在用,在terminal里面打ssh就完事了呀)。 恩,恩,莫非是公钥格式不一样? 而且看了一大堆都是怎样配置的,虽然说要用起来我们必须先设置好,但是我觉得如果能加上其他高阶的东西这样会更实用些,比如如何建立ssh隧道,如何自由的使用隧道来加密所需数据/服务,如何穿防火墙,如果建虚拟网络等。 以上的总总都需要ssh的转端口的强大功能(local and remote port forwarding)。如果楼上愿意一起写的话,给小弟发个email: chencontact@yahoo.co.uk |
初学vb 回复于:2005-01-11 11:15:11 |
两个UNIX类相互的不用密码的通信完成了!大家看看吧!! 3、UNIX类客户端—UNIX类服务端 1、运行环境 两边都是UNIX类的服务器A和B,都已经安装了SSH Secure Shell 的服务器程序且运行正常。我们需要实现的是从主机A登陆到主机B上,不需要密码。 2、生成密钥过程 在主机A上: # cd /usr/local/bin # ./ssh-keygen2 -t rsa 默认密钥的位数是2048,当提示你Passphrase 的时候,直接按两次回车跳过,成功后会提示如下: Private key saved to /root/.ssh2/id_rsa_2048_a Public key saved to /root/.ssh2/id_rsa_2048_a.pub 3、从A登陆到B过程 我们进入当前A机器用户的ssh2目录,创建一个认证文件,步骤如下: # cd ~/.ssh2 # echo "IdKey id_rsa_2048_a" > identification 取保id_rsa_2048_a 和 identification是在同一个目录下,好了,在主机A上我们的步骤就完成了。 然后我们就把id_rsa_2048_a.pub传到我们要ssh到的主机B上。这个步骤略过。 ssh登陆到主机B上,在B上的用户ssh2目录下创建一个authorization文件,步骤如下: # cd ~/.ssh2 # echo “key id_rsa_2048_a.pub” >> authorization //注意我们这里是追加 退出主机B,回到主机A # ssh [IP OF B] 显示Authentication successful.不需要密码了!!否则会显示Authentication failure.你得查查哪有问题了。当然我们还要在B服务器上修改/etc/ssh2/sshd2_config文件 把以下如下三行的password 删除,下面这三行是修改好的 AllowedAuthentications publickey AllowedAuthentications hostbased,publickey RequiredAuthentications publickey 这样才达到了我们的目的呢!! |
初学vb 回复于:2005-01-11 11:59:08 |
[quote:8cfcf2aa2a="samme"] 请楼上说的明白些,我真的是不明白两台unix的机子相互认证会出来什么问题?(我是天天在用,在terminal里面打ssh就完事了呀)。 恩,恩,莫非是公钥格式不一样? 而且看了一大堆都是怎样配置的,虽然说要用起?.........[/quote:8cfcf2aa2a] 兄弟,看看我上面的UNIX类之间的相互通信你就能明白了!!最好对比一下WIN和UNIX类的,不太一样!! |
samme 回复于:2005-01-11 18:47:06 |
[quote:4da83d22cb="初学vb"] 兄弟,看看我上面的UNIX类之间的相互通信你就能明白了!!最好对比一下WIN和UNIX类的,不太一样!![/quote:4da83d22cb] 你后半句话的意思是不是不要让我用win的经验来套用unix?我可以肯定的告诉你我现在的电脑上没有windows,在可见的将来我也没有打算去装。 我用的是被你贬的一无是处的openssh(很可惜,就是这样的一个漏洞奇多的ssh服务/客户端拥有88%的市场占有率). alpha连linux, linux连alpha没有任何问题,而且配置非常简单(当然,我说的是你一直强调的不用密码连接的非常实用的功能)。 只需要把自己的public key放到对方服务器上的 authorized_keys 里面就可以。再提醒一下传文件是不必须的(就像你在上面做的把public key以文件的形式传到对方服务器上)。 很遗憾,看来port forwarding 只能自己写了。 |
初学vb 回复于:2005-01-11 22:24:22 |
[quote:7b731249d5="samme"] 你后半句话的意思是不是不要让我用win的经验来套用unix?我可以肯定的告诉你我现在的电脑上没有windows,在可见的将来我也没有打算去装。 我用的是被你贬的一无是处的openssh(很可惜,就是这样的一个漏洞奇多?.........[/quote:7b731249d5] 首先,我要感谢你的直率,有话就说,在我生活的圈子中已经很少有人能这么讲话了.(完全没有贬义,别误会!!只是感慨一下!!) 我对你的问题的答复: 对于OPENSSH的理解只是我的个人看法,用什么服务器端或客户端都是个人的权利.我不会在我的文章里强迫大家用SSH的,当然如果你认为openssh好那么我建议你写一篇OPENSSH的文档给大家,让大家共同进步! 另:我也强调了余下的部分我一直在写,只是时间的安排上有些问题;如果你能先写出来关于SSH的隧道加密功能的文档,我是十分欢迎的,毕竟大家都对SSH这种安全工具和技术投入了很大的热情,有了大家的投入,我相信网络安全会在大家心中占有一席之地的. 希望我们大家都能在CU大家庭这个友好的环境中共同探讨问题! |
初学vb 回复于:2005-01-11 22:43:09 |
WIN之间的SSH方法我已经写完了,但考虑到大家看的方便,抓了大部分的图,连密钥的生成方法也用图来表示了!考虑到CU不支持贴图的功能,这个方法就先保留不发了,现在还在赶制PDF,我在这个帖子里发表的一切以后都能在PDF里找到,PDF就起名叫SSH系列教程了! |
Macolex 回复于:2005-01-12 03:18:26 |
[quote:33ab7dbaca="delphij"]OpenSSH. ssh是商业软件,而说OpenSSH安全漏洞多……上次OpenSSH漏洞什么时候来着? 2003年10月,一年多以前的事情了。 OpenBSD的人在安全方面有非常多的创新,更何况安全绝不是换个软件就顶用的。 [/quote:33ab7dbaca] |
網中人 回复于:2005-01-12 08:02:31 |
寫得很不錯! 先鼓勵一下! 然而, 必須提醒一下: ssh 的使用, 尤其是 ssh v2, 是有限制的. 使用前最好讀清楚其授權條款, 特別是商業用戶. 若用 open ssh, 則無此慮... 至於安全漏洞, 容我公平的說一句: 只要是人寫的, 就不能保證沒有安全漏洞! 從這個基礎出發, openssh 與 ssh 都是平等的. 關鍵還是使用端的管理員是否建立起足夠的安全觀念及操作. 我認為樓主單方面抨擊 openssh 的安全性, 似乎有那麼一丁點兒失卻公允呢. 至於 unix-like OS (如 linux) 上設定 rsa/dsa key 的驗證, 基本上不用超過 3 行 command line 就可搞定了: keygen 跑一跑 scp public key 進 remote ssh 操作 remote 將 key 加入 authorized_keys 最後, 也很期待 port forward, X11 forward 等方面的文檔. 給樓主加油! |
初学vb 回复于:2005-01-12 09:33:43 |
感谢大家的鼓励,我会再接再励的! 其实SSH的原理都是一样的,只不过每个公司的产品有每个公司的特色,如果通一个,其他的也都是万变不离其宗的! 我对OPENSSH的理解是我个人的看法,我会在文章中把贬义的词删除,让大家自己做判断。 |
初学vb 回复于:2005-01-12 09:48:20 |
[quote:0df419a266="Macolex"][/quote:0df419a266] 巧了,ssh现在的最新版本也是2003-10-01 12:00发布的! |
山中无老虎 回复于:2005-01-12 10:02:06 |
使用SSH时一定要注意,不同的SSH工具所生成的密钥是不能通用的。另外按我的实践,在Linux下生成的SSH目录应为~下的.ssh而不是.ssh2,不知是不是这样。还有就是两台机器登录时不需不需要密码是由设置决定的,并不是从根本上不需要。 |
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/