當前位置: 首頁>>代碼示例>>Python>>正文


Python RSAKey.from_private_key_file方法代碼示例

本文整理匯總了Python中paramiko.RSAKey.from_private_key_file方法的典型用法代碼示例。如果您正苦於以下問題:Python RSAKey.from_private_key_file方法的具體用法?Python RSAKey.from_private_key_file怎麽用?Python RSAKey.from_private_key_file使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在paramiko.RSAKey的用法示例。


在下文中一共展示了RSAKey.from_private_key_file方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def __init__(self, host, port, tun_host, tun_port, tun_user, tun_password, pkey_path, pkey_password):
        self.host = host
        self.port = int(port)
        self.tun_host = tun_host
        self.tun_port = int(tun_port)
        self.tun_user = tun_user
        self.tun_password = tun_password

        if pkey_path:
            self.private_key = RSAKey.from_private_key_file(pkey_path, password=pkey_password)
            self.server = SSHTunnelForwarder(
                ssh_address_or_host=(self.tun_host, self.tun_port),
                ssh_username=self.tun_user,
                ssh_pkey=self.private_key,
                remote_bind_address=(self.host, self.port),
            )
        else:
            self.server = SSHTunnelForwarder(
                ssh_address_or_host=(self.tun_host, self.tun_port),
                ssh_username=self.tun_user,
                ssh_password=self.tun_password,
                remote_bind_address=(self.host, self.port),
            )
        self.server.start() 
開發者ID:hhyo,項目名稱:Archery,代碼行數:26,代碼來源:ssh_tunnel.py

示例2: test_18_load_ecdsa_521

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_18_load_ecdsa_521(self):
        key = ECDSAKey.from_private_key_file(test_path('test_ecdsa_521.key'))
        self.assertEqual('ecdsa-sha2-nistp521', key.get_name())
        exp_ecdsa = b(FINGER_ECDSA_521.split()[1].replace(':', ''))
        my_ecdsa = hexlify(key.get_fingerprint())
        self.assertEqual(exp_ecdsa, my_ecdsa)
        self.assertEqual(PUB_ECDSA_521.split()[1], key.get_base64())
        self.assertEqual(521, key.get_bits())

        s = StringIO()
        key.write_private_key(s)
        # Different versions of OpenSSL (SSLeay versions 0x1000100f and
        # 0x1000207f for instance) use different apparently valid (as far as
        # ssh-keygen is concerned) padding. So we can't check the actual value
        # of the pem encoded key.
        s.seek(0)
        key2 = ECDSAKey.from_private_key(s)
        self.assertEqual(key, key2) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:20,代碼來源:test_pkey.py

示例3: ensure_local_ssh_key

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def ensure_local_ssh_key(name):
    from paramiko import RSAKey
    if os.path.exists(get_ssh_key_path(name)):
        ssh_key = RSAKey.from_private_key_file(get_ssh_key_path(name))
    else:
        logger.info("Creating key pair %s", name)
        ssh_key = new_ssh_key()
        makedirs(os.path.dirname(get_ssh_key_path(name)), exist_ok=True)
        ssh_key.write_private_key_file(get_ssh_key_path(name))
    return ssh_key 
開發者ID:kislyuk,項目名稱:aegea,代碼行數:12,代碼來源:crypto.py

示例4: _load_rsa_key

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def _load_rsa_key(self, path, passphrase):
        return RSAKey.from_private_key_file(path, password=passphrase) 
開發者ID:Kitware,項目名稱:cumulus,代碼行數:4,代碼來源:ssh.py

示例5: run_ssh_command

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def run_ssh_command(self, command):
    key = task_key(self.request.id)
    redis.set(key, "")
    client = SSHClient()
    client.set_missing_host_key_policy(AutoAddPolicy)
    known_hosts = os.path.expanduser('~/.ssh/known_hosts')
    try:
        client.load_host_keys(known_hosts) # So that we also save back the new host
    except FileNotFoundError:
        if not os.path.exists(os.path.dirname(known_hosts)):
            os.mkdir(os.path.dirname(known_hosts))
        open(known_hosts, "w").write("") # so connect doesn't barf when trying to save
    if type(command) == list:
        commands = command
    else:
        commands = [command]
    for c in commands:
        if os.path.exists(keyfile):
            pkey = RSAKey.from_private_key_file(keyfile)
        else:
            pkey = None
        client.connect(settings.DOKKU_HOST, port=settings.DOKKU_SSH_PORT, username="dokku", pkey=pkey, allow_agent=False, look_for_keys=False)
        transport = client.get_transport()
        channel = transport.open_session()
        channel.exec_command(c)
        while True:
            anything = False
            while channel.recv_ready():
                data = channel.recv(1024)
                handle_data(key, data)
                anything = True
            while channel.recv_stderr_ready():
                data = channel.recv_stderr(1024)
                handle_data(key, data)
                anything = True
            if not anything:
                if channel.exit_status_ready():
                    break
                time.sleep(0.1)
    return redis.get(key).decode("utf-8") 
開發者ID:palfrey,項目名稱:wharf,代碼行數:42,代碼來源:tasks.py

示例6: test_2_load_rsa

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_2_load_rsa(self):
        key = RSAKey.from_private_key_file(test_path('test_rsa.key'))
        self.assertEqual('ssh-rsa', key.get_name())
        exp_rsa = b(FINGER_RSA.split()[1].replace(':', ''))
        my_rsa = hexlify(key.get_fingerprint())
        self.assertEqual(exp_rsa, my_rsa)
        self.assertEqual(PUB_RSA.split()[1], key.get_base64())
        self.assertEqual(1024, key.get_bits())

        s = StringIO()
        key.write_private_key(s)
        self.assertEqual(RSA_PRIVATE_OUT, s.getvalue())
        s.seek(0)
        key2 = RSAKey.from_private_key(s)
        self.assertEqual(key, key2) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:17,代碼來源:test_pkey.py

示例7: test_3_load_rsa_password

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_3_load_rsa_password(self):
        key = RSAKey.from_private_key_file(test_path('test_rsa_password.key'), 'television')
        self.assertEqual('ssh-rsa', key.get_name())
        exp_rsa = b(FINGER_RSA.split()[1].replace(':', ''))
        my_rsa = hexlify(key.get_fingerprint())
        self.assertEqual(exp_rsa, my_rsa)
        self.assertEqual(PUB_RSA.split()[1], key.get_base64())
        self.assertEqual(1024, key.get_bits()) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:10,代碼來源:test_pkey.py

示例8: test_4_load_dss

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_4_load_dss(self):
        key = DSSKey.from_private_key_file(test_path('test_dss.key'))
        self.assertEqual('ssh-dss', key.get_name())
        exp_dss = b(FINGER_DSS.split()[1].replace(':', ''))
        my_dss = hexlify(key.get_fingerprint())
        self.assertEqual(exp_dss, my_dss)
        self.assertEqual(PUB_DSS.split()[1], key.get_base64())
        self.assertEqual(1024, key.get_bits())

        s = StringIO()
        key.write_private_key(s)
        self.assertEqual(DSS_PRIVATE_OUT, s.getvalue())
        s.seek(0)
        key2 = DSSKey.from_private_key(s)
        self.assertEqual(key, key2) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:17,代碼來源:test_pkey.py

示例9: test_5_load_dss_password

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_5_load_dss_password(self):
        key = DSSKey.from_private_key_file(test_path('test_dss_password.key'), 'television')
        self.assertEqual('ssh-dss', key.get_name())
        exp_dss = b(FINGER_DSS.split()[1].replace(':', ''))
        my_dss = hexlify(key.get_fingerprint())
        self.assertEqual(exp_dss, my_dss)
        self.assertEqual(PUB_DSS.split()[1], key.get_base64())
        self.assertEqual(1024, key.get_bits()) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:10,代碼來源:test_pkey.py

示例10: test_6_compare_rsa

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_6_compare_rsa(self):
        # verify that the private & public keys compare equal
        key = RSAKey.from_private_key_file(test_path('test_rsa.key'))
        self.assertEqual(key, key)
        pub = RSAKey(data=key.asbytes())
        self.assertTrue(key.can_sign())
        self.assertTrue(not pub.can_sign())
        self.assertEqual(key, pub) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:10,代碼來源:test_pkey.py

示例11: test_8_sign_rsa

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_8_sign_rsa(self):
        # verify that the rsa private key can sign and verify
        key = RSAKey.from_private_key_file(test_path('test_rsa.key'))
        msg = key.sign_ssh_data(b'ice weasels')
        self.assertTrue(type(msg) is Message)
        msg.rewind()
        self.assertEqual('ssh-rsa', msg.get_text())
        sig = bytes().join([byte_chr(int(x, 16)) for x in SIGNED_RSA.split(':')])
        self.assertEqual(sig, msg.get_binary())
        msg.rewind()
        pub = RSAKey(data=key.asbytes())
        self.assertTrue(pub.verify_ssh_sig(b'ice weasels', msg)) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:14,代碼來源:test_pkey.py

示例12: test_9_sign_dss

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_9_sign_dss(self):
        # verify that the dss private key can sign and verify
        key = DSSKey.from_private_key_file(test_path('test_dss.key'))
        msg = key.sign_ssh_data(b'ice weasels')
        self.assertTrue(type(msg) is Message)
        msg.rewind()
        self.assertEqual('ssh-dss', msg.get_text())
        # can't do the same test as we do for RSA, because DSS signatures
        # are usually different each time.  but we can test verification
        # anyway so it's ok.
        self.assertEqual(40, len(msg.get_binary()))
        msg.rewind()
        pub = DSSKey(data=key.asbytes())
        self.assertTrue(pub.verify_ssh_sig(b'ice weasels', msg)) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:16,代碼來源:test_pkey.py

示例13: test_10_load_ecdsa_256

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_10_load_ecdsa_256(self):
        key = ECDSAKey.from_private_key_file(test_path('test_ecdsa_256.key'))
        self.assertEqual('ecdsa-sha2-nistp256', key.get_name())
        exp_ecdsa = b(FINGER_ECDSA_256.split()[1].replace(':', ''))
        my_ecdsa = hexlify(key.get_fingerprint())
        self.assertEqual(exp_ecdsa, my_ecdsa)
        self.assertEqual(PUB_ECDSA_256.split()[1], key.get_base64())
        self.assertEqual(256, key.get_bits())

        s = StringIO()
        key.write_private_key(s)
        self.assertEqual(ECDSA_PRIVATE_OUT_256, s.getvalue())
        s.seek(0)
        key2 = ECDSAKey.from_private_key(s)
        self.assertEqual(key, key2) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:17,代碼來源:test_pkey.py

示例14: test_11_load_ecdsa_password_256

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_11_load_ecdsa_password_256(self):
        key = ECDSAKey.from_private_key_file(test_path('test_ecdsa_password_256.key'), b'television')
        self.assertEqual('ecdsa-sha2-nistp256', key.get_name())
        exp_ecdsa = b(FINGER_ECDSA_256.split()[1].replace(':', ''))
        my_ecdsa = hexlify(key.get_fingerprint())
        self.assertEqual(exp_ecdsa, my_ecdsa)
        self.assertEqual(PUB_ECDSA_256.split()[1], key.get_base64())
        self.assertEqual(256, key.get_bits()) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:10,代碼來源:test_pkey.py

示例15: test_12_compare_ecdsa_256

# 需要導入模塊: from paramiko import RSAKey [as 別名]
# 或者: from paramiko.RSAKey import from_private_key_file [as 別名]
def test_12_compare_ecdsa_256(self):
        # verify that the private & public keys compare equal
        key = ECDSAKey.from_private_key_file(test_path('test_ecdsa_256.key'))
        self.assertEqual(key, key)
        pub = ECDSAKey(data=key.asbytes())
        self.assertTrue(key.can_sign())
        self.assertTrue(not pub.can_sign())
        self.assertEqual(key, pub) 
開發者ID:hpe-storage,項目名稱:python-hpedockerplugin,代碼行數:10,代碼來源:test_pkey.py


注:本文中的paramiko.RSAKey.from_private_key_file方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。