免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2592 | 回复: 0
打印 上一主题 下一主题

paramiko.PasswordRequiredException: Private key file is encrypted 求大神解决 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-07-09 13:49 |只看该作者 |倒序浏览
各位大神,小弟刚接触paramiko,想使用私钥登录,结果包错。求帮助

1、在root下生成 id_rsa
chmod 700 ~/.ssh/
ssh-keygen -t rsa

2、代码部分
#!/usr/bin/python

import paramiko
import socket
import sys,os

host = sys.argv[1]
user = sys.argv[2]
port = int(sys.argv[3])
auth_method = sys.argv[4]

if auth_method == 'PASSWORD':
    password = sys.argv[5]
    cmd = sys.argv[6]
else:
    cmd = sys.argv[5]

s = paramiko.SSHClient()
s.load_system_host_keys()
s.set_missing_host_key_policy(paramiko.AutoAddPolicy())

if auth_method == "SSH_KEY":
    pkey_file='/root/.ssh/id_rsa'
    key_p = paramiko.RSAKey.from_private_key_file(pkey_file)
    s.connect(host,port,user,pkey=key_p,timeout=60)
elif auth_method == "PASSWORD":
    s.connect(host,port,user,password,timeout=60)
stdin,stdout,stderr = s.exec_command(cmd)
cmd_result = stdout.read(),stderr.read()
print '----------Result from %s ------------' % host
for line in cmd_result:
    print line,
s.close()

# ./paramiko.sangle1.py 127.0.0.1 root 22 SSH_KEY ls


报错
Traceback (most recent call last):
  File "./paramiko.sangle1.py", line 29, in <module>
    s.connect(host,port,user,pkey=key_p,timeout=60)
  File "/usr/lib/python2.6/site-packages/paramiko-1.10.1-py2.6.egg/paramiko/client.py", line 337, in connect
    self._auth(username, password, pkey, key_filenames, allow_agent, look_for_keys)
  File "/usr/lib/python2.6/site-packages/paramiko-1.10.1-py2.6.egg/paramiko/client.py", line 528, in _auth
    raise saved_exception
paramiko.PasswordRequiredException: Private key file is encrypted
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP