利用shell祕鑰登錄服務器

------------恢復內容開始------------

一、點擊Xshell菜單欄的工具,選擇新建用戶密鑰生成嚮導,進行密鑰對生成操作。

注意選擇長度爲2048位祕鑰;

二、修改sshd的配置文件,啓用密鑰認證登錄,同時關閉密碼認證,並重啓服務

三、進入家目錄的.ssh目錄下,將生成的公鑰拷貝到authorized_keys文件中,並賦予600權限

1、公鑰的位置

2、將公鑰拷貝到authorized_keys文件

另外特別注意:

上傳公鑰至服務器之後要修改 

A - 將我們生成的webuse.pub公鑰文件上傳到/webuse/.ssh文件夾下面(如果沒有我們需要創建),然後我們需要將webuse.pub重命名爲authorized_keys (千萬寫敲錯)並且用chmod 600 authorized_keys設置權限。

B - 找到/etc/ssh/sshd_config ,把RSAAuthentication和PubkeyAuthentication兩行前面的#註釋去掉。(這是重點)

C - 重啓SSHD服務

關閉遠程linux防火牆,千萬不要漏掉這一部分;(哥們沒有設置,照樣成功!)
永久關閉selinux
 #vi /etc/selinux/config        #修改selinux的配置文件
更改“SELINUX=enforcing”爲 SELINUX=disabled  保存退出。
[root@localhost ~]# /usr/sbin/sestatus -v        #查看selinux的狀態命令
SELinux status:                disabled
關閉防火牆
[root@localhost ~]# iptables -F                                #清空防火牆配置
[root@localhost ~]# /etc/init.d/iptables save          #清空防火牆配置後,記得保存
iptables:將防火牆規則保存到 /etc/sysconfig/iptables:    [確定]

四、進行登錄

注:

錯誤提示:

xshell登錄時,提示“所選的用戶密鑰未在遠程主機上註冊 ”

跟蹤

登陸目標機器,查看sshd的日誌信息。日誌信息目錄爲,/var/log/secure
你會發現如下字樣的日誌信息。
Jul 22 14:20:33 v138020.go sshd[4917]: Authentication refused: bad ownership or modes for directory /home/webuser

原因

sshd爲了安全,對屬主的目錄和文件權限有所要求。如果權限不對,則ssh的免密碼登陸不生效。
用戶目錄權限爲 755 或者 700,就是不能是77x。
.ssh目錄權限一般爲755或者700。
rsa_id.pub 及authorized_keys權限一般爲644
rsa_id權限必須爲600

解決方法

檢測目錄權限,把不符合要求的按要求設置權限即可。

我的網站目錄也在當前用戶家目錄下  單獨設置權限即可

版權聲明:本文爲CSDN博主「幸福丶如此」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。

原文鏈接:https://blog.csdn.net/m0_37886429/article/details/78422914

------------恢復內容結束------------

一、點擊Xshell菜單欄的工具,選擇新建用戶密鑰生成嚮導,進行密鑰對生成操作。

注意選擇長度爲2048位祕鑰;

二、修改sshd的配置文件,啓用密鑰認證登錄,同時關閉密碼認證,並重啓服務

三、進入家目錄的.ssh目錄下,將生成的公鑰拷貝到authorized_keys文件中,並賦予600權限

1、公鑰的位置

2、將公鑰拷貝到authorized_keys文件

另外特別注意:

上傳公鑰至服務器之後要修改 

A - 將我們生成的webuse.pub公鑰文件上傳到/webuse/.ssh文件夾下面(如果沒有我們需要創建),然後我們需要將webuse.pub重命名爲authorized_keys (千萬寫敲錯)並且用chmod 600 authorized_keys設置權限。

B - 找到/etc/ssh/sshd_config ,把RSAAuthentication和PubkeyAuthentication兩行前面的#註釋去掉。(這是重點)

C - 重啓SSHD服務

關閉遠程linux防火牆,千萬不要漏掉這一部分;(哥們沒有設置,照樣成功!)
永久關閉selinux
 #vi /etc/selinux/config        #修改selinux的配置文件
更改“SELINUX=enforcing”爲 SELINUX=disabled  保存退出。
[root@localhost ~]# /usr/sbin/sestatus -v        #查看selinux的狀態命令
SELinux status:                disabled
關閉防火牆
[root@localhost ~]# iptables -F                                #清空防火牆配置
[root@localhost ~]# /etc/init.d/iptables save          #清空防火牆配置後,記得保存
iptables:將防火牆規則保存到 /etc/sysconfig/iptables:    [確定]

四、進行登錄

注:

錯誤提示:

xshell登錄時,提示“所選的用戶密鑰未在遠程主機上註冊 ”

跟蹤

登陸目標機器,查看sshd的日誌信息。日誌信息目錄爲,/var/log/secure
你會發現如下字樣的日誌信息。
Jul 22 14:20:33 v138020.go sshd[4917]: Authentication refused: bad ownership or modes for directory /home/webuser

原因

sshd爲了安全,對屬主的目錄和文件權限有所要求。如果權限不對,則ssh的免密碼登陸不生效。
用戶目錄權限爲 755 或者 700,就是不能是77x。
.ssh目錄權限一般爲755或者700。
rsa_id.pub 及authorized_keys權限一般爲644
rsa_id權限必須爲600

解決方法

檢測目錄權限,把不符合要求的按要求設置權限即可。

我的網站目錄也在當前用戶家目錄下  單獨設置權限即可

版權聲明:本文爲CSDN博主「幸福丶如此」及wuling129的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。

原文鏈接:https://blog.csdn.net/m0_37886429/article/details/78422914及https://www.cnblogs.com/wuling129/p/4665001.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章