我正在使用Paramiko通过ssh连接到服务器。
基本身份验证效果很好,但我不明白如何使用公钥进行连接。
当我连接腻子时,服务器告诉我这一点:
Using username "root".
Authenticating with public key "rsa-key@ddddd.com"
Passphrase for key "rsa-key@ddddd.com": [i've inserted the passphrase here]
Last login: Mon Dec 5 09:25:18 2011 from ...
我用这个ppk文件连接到它:
PuTTY-User-Key-File-2: ssh-rsa
Encryption: aes256-cbc
Comment: rsa-key@dddd.com
Public-Lines: 4
[4 lines key]
Private-Lines: 8
[8 lines key]
Private-MAC: [hash]
使用基本身份验证,我从日志中得到的错误是:
DEB [20111205-09:48:44.328] thr=1 paramiko.transport: userauth is OK
DEB [20111205-09:48:44.927] thr=1 paramiko.transport: Authentication type (password) not permitted.
DEB [20111205-09:48:44.927] thr=1 paramiko.transport: Allowed methods: ['publickey', 'gssapi-with-mic']
我尝试包含该ppk文件并将其设置为auth_public_key,但是没有用。
你能帮助我吗?
好的@Adam和@Kimvais是正确的,paramiko无法解析.ppk文件。
因此,方法(也要感谢@JimB)是将.ppk文件转换为openssh私钥格式;这可以使用来实现的puttygen描述这里。
然后,很简单地与之建立联系:
import paramiko
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect('<hostname>', username='<username>', password='<password>', key_filename='<path/to/openssh-private-key-file>')
stdin, stdout, stderr = ssh.exec_command('ls')
print stdout.readlines()
ssh.close()
问题内容: Doc缺少示例…您如何基于密钥使用? 尝试根据键插入。 将插入位置放在。 从文档… A,X,LO = 0,HI = LEN(a)中 插入 X 在 一个 按排序顺序。这等效于假设 a 已经排序。请记住,O(log n)搜索由缓慢的O(n)插入步骤主导。 用法示例: 我希望把后排序列表中使用。眼下看跌期权的......因为我不使用的钥匙,做插入…文档不显示做用钥匙插入。 问题答案: 这确实
以下命令生成一个包含公钥和私钥的文件: 资料来源:这里 使用OpenSSL,私钥也包含公钥信息,因此公钥不需要单独生成 如何从私钥中提取公钥。pem文件? 谢谢
我想知道如何使用公钥来验证私钥。 “<代码> <模数> 这是一个字符串,我试图使用Python验证它的私钥(也是作为字符串提供的)。我知道发行人和观众需要做什么,但我不确定如何处理所有这些信息。 我看了一些peoples使用各种包的例子,但我似乎不知道pub_key、private_key和message是什么类型...请帮帮我...我希望学习
问题内容: 我正在尝试使用以下代码建立新的PDO连接。 我不确定要使用什么驱动程序?或如何安装它们。我可以使用PHP中的函数进行完美连接,但我想改用PDO库。 我的mssql设置是: 问题答案: PDO mssql驱动程序不再可用,请使用(在php Windows下)或(在php linux下) http://msdn.microsoft.com/zh- CN/sqlserver/ff657782
我对Android编程感兴趣。我正在使用对称和非对称加密,我想用公钥包装Android Key Store中的密钥,但失败了。我可以从Key Store中获取密钥,但无法包装。 错误: InvalidKeyException:无法包装键,空编码 我尝试在上面的代码中使用这个密钥对和秘密密钥——我通过对称和非对称加密成功地加密和解密了一些字符串。 有趣的是什么?我试图通过KeyGenerator生成
问题内容: keytool中是否可以打印证书的公钥?我试过了: 但是它仅提供以下信息: 在此没有公钥。 问题答案: 您可以使用做到这一点。 如果此证书是DER编码的(二进制),请使用: 用于PEM编码的使用选项(或完全不设置)。 要查看公钥的详细信息,请使用: