用key方式登录ssh

如果你打算在windows下访问另外一台装有Linux的机子(系统管理员对公司服务器管理或个人站长对vps的管理……),那么推荐使用putty (当然你的linux必须已经安装了ssh服务器才行。)

SSH提供两种级别的安全验证: 一是基于口令的安全验证。只要用户知道自己账号和口令,就可以登录到远程主机。所有传输的数据都会被加密,但是不能保证用户正在连接的服务器就是用户想连接的服务器。可能会有别的服务器在冒充真正的服务器,这存在着潜在的威胁。
二是基于密匙的安全验证。需要依靠密匙,也就是用户必须为自己创建一对公匙/密钥对,并把公用密匙放在需要访问的服务器上。如果需要连接到SSH服务器上,客户端软件就会向服务器发出请求,请求使用用户的密匙进行安全验证。服务器收到请求之后,先在服务器上用户的主目录下找到该用户的公用密匙,然后把它和用户发送过来的公用密匙进行比较。如果两个密匙一致,服务器就用公用密匙加密“质询”并把它发送给客户端软件。客户端软件收到“质询”之后就可以用用户的私人密匙解密再把它发送给服务器。

一、通过方式一:口令认证登陆
1、打开putty.exe
1)、Session –> Host Name (填写服务器地址或者域名,如:192.168.0.250s)
如果远程主机存在提示如下:

login as: root
root@192.168.0.250′s password:正确输入密码后即可正常登陆远程Linux主机
(注意:
远程Linux主机的/etc/ssh/sshd_config配置文件
PasswordAuthentication 必须为 yes
修改后/etc/init.d/sshd reload #加载修改后的配置文件并生效

二、通过方式二:密匙认证登陆
方案一:使用puttygen.exe生成的密匙
1、用puttygen.exe生成一对密匙
1)、打开puttygen.exe,直接点击Generate,鼠标在Key区空白的位置频繁的晃动
加快随机数的产生,这样几秒钟就可以生成我们需要的密匙
2)、在key comment填写信息,相当于备注
在key passphrase处填写key的密码
3)、将上面框框内的东西(公钥)粘贴到/root/.ssh/authorized_keys文件里,没有的话,新建这个文件。这样sshd服务程序当接收到远程客户端的连接申请时会自动匹配.ssh/authorized_keys文件中的密匙
4)、点击Save private key->id_rsa.ppk(保存私钥)
如果安全级别不是很苛刻,可以不设置Key passphrase
2、打开putty.exe
1)、Session –> Host Name (填写服务器地址或者域名)
2)、Connection –> SSH –> Auth (点Browse选择刚生成的id_rsa.ppk)
3)、open
成功打开后出现如下提示:

login as: root
Authenticating with public key “imported-openssh-key”方案二:使用Linux主机生成的密匙
1、生成密匙

[root@gliethttp .ssh]#ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
e4:9a:47:a7:b4:8a:0b:98:07:b8:70:de:6b:16:2c:0c root@gliethttp2、将/root/.ssh/id_rsa.pub改名为/root/.ssh/authorized_keys
[root@gliethttp .ssh]#mv /root/.ssh/id_rsa.pub /root/.ssh/authorized_keys
3、将私钥id_rsa拷贝到远程客户端
1)、如果远程客户端是linux,拷贝到远程客户端/root/.ssh/即可
2)、putty作为远程客户端在
putty不能识别直接从服务器拷贝来的私钥,需要使用puttygen.exe进行格式转换
(1)、打开puttygen.exe –> Conversions –> Import Key
(2)、选择拷贝过来的私钥文件id_rsa
(3)、Save private key->id_rsa.ppk(保存私钥)
4、打开putty.exe
1)、Session –> Host Name (填写服务器地址或者域名)
2)、Connection –> SSH –> Auth (点Browse选择刚生成的id_rsa.ppk)
3)、open
成功打开后出现如下提示:

login as: root
Authenticating with public key “imported-openssh-key”—————————————————————
如果我们只希望有私钥的远程客户机才能通过ssh登陆本主机,那么
远程Linux主机的/etc/ssh/sshd_config配置文件
PasswordAuthentication 改为 no
修改后/etc/init.d/sshd reload #加载修改后的配置文件并生效
这样其他远程客户端如果没有私钥,那么这些用户连输入密码的机会都没有,就会被本主机直接断开
—————————————————————
如果不允许root登陆,那么
PermitRootLogin no
—————————————————————
我们的/etc/ssh/sshd_config内容

# Customize sshd config
cat << EOF > /etc/ssh/sshd_config
Protocol 2
SyslogFacility AUTHPRIV
MaxAuthTries 4
#主要修改了下面两行,其他的都是默认
PermitRootLogin no
PasswordAuthentication no
ChallengeResponseAuthentication no
GSSAPIAuthentication yes
GSSAPICleanupCredentials yes
UsePAM yes
AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
AcceptEnv LC_IDENTIFICATION LC_ALL
X11Forwarding yes
Subsystem sftp /usr/libexec/openssh/sftp-server
EOF**************************************
注意:
如果putty.exe不能登陆远程主机,请查看如下几个选项是否符合:
1)、远程主机的防火墙是否关闭,通过如下指令关闭防火墙:
[root@gliethttp root]#/etc/init.d/iptables stop
2)、远程主机是否启动sshd,通过如下指令启动:
[root@gliethttp root]#/etc/init.d/sshd start
*****************************************


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows系统中使用SSH(Secure Shell)进行免密登录通常需要借助第三方工具,如PuTTY、Pageant等。这里我将为你提供一个基本的批处理脚本示例,假设你已经安装了PuTTY,并且使用了Pageant作为SSH密钥对管理器: ```batch @echo off set SSH_DIR=C:\path\to\your\pageant.exe %~dp0 # 设置Pageant的位置和当前脚本的目录 set PASS_FILE=C:\path\to\your\private_key.pem # 设置私钥文件路径 REM 启动Pageant并加载私钥 start "" %SSH_DIR% %PASS_FILE% REM 使用PuTTY连接到远程服务器,替换"username"和"hostname"为实际值 timeout /t 10 putty -load "SSH_NAME" -ssh username@hostname pause ``` 在这个脚本中: - `@echo off` 关闭命令行回显,使得脚本执行更整洁。 - `set SSH_DIR` 和 `set PASS_FILE` 分别设置Pageant的路径和私钥文件路径。 - `start "" %SSH_DIR% %PASS_FILE%` 启动Pageant并自动加载私钥,`""` 参数表示无标题栏。 - `timeout /t 10` 延迟10秒,给Pageant足够时间加载密钥。 - `putty -load "SSH_NAME" -ssh username@hostname` 使用PuTTY连接到服务器,`SSH_NAME` 是你在PuTTY配置中为这个服务器设置的名称。 注意: 1. 你需要将`SSH_DIR`、`PASS_FILE`、`username`和`hostname`替换为实际的路径和用户名/主机名。 2. 在PuTTY中,需要为SSH配置一个会话(Session),并将其保存为一个名字(如"SSH_NAME"`),以便在此脚本中调用。 3. 执行此脚本前,确保PuTTY和Pageant已添加到系统的PATH环境变量中,或者提供完整的路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值