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


Python RSA.importKey方法代碼示例

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


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

示例1: get_public_keys

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def get_public_keys(self, params, emails):
        # type: (EnterpriseCommand, KeeperParams, dict) -> None

        for email in emails:
            emails[email] = self.public_keys.get(email.lower())

        email_list = [x[0] for x in emails.items() if x[1] is None]
        if len(email_list) == 0:
            return

        rq = {
            'command': 'public_keys',
            'key_owners': email_list
        }
        rs = api.communicate(params, rq)
        for pko in rs['public_keys']:
            if 'public_key' in pko:
                public_key = RSA.importKey(base64.urlsafe_b64decode(pko['public_key'] + '=='))
                self.public_keys[pko['key_owner'].lower()] = public_key
                emails[pko['key_owner']] = public_key 
開發者ID:Keeper-Security,項目名稱:Commander,代碼行數:22,代碼來源:enterprise.py

示例2: accept_account_transfer_consent

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def accept_account_transfer_consent(params, share_account_to):
    print('')
    answer = input('Do you accept Account Transfer policy? Accept/C(ancel): ')
    answer = answer.lower()
    if answer.lower() == 'accept':
        for role in share_account_to:
            public_key = RSA.importKey(base64.urlsafe_b64decode(role['public_key'] + '=='))
            transfer_key = encrypt_rsa(params.data_key, public_key)
            request = {
                'command': 'share_account',
                'to_role_id': role['role_id'],
                'transfer_key': transfer_key
            }
            communicate(params, request)
        return True
    else:
        logging.info('Canceled')

    return False 
開發者ID:Keeper-Security,項目名稱:Commander,代碼行數:21,代碼來源:api.py

示例3: decrypt_rsa_key

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def decrypt_rsa_key(encrypted_private_key, data_key):
    """ Decrypt the RSA private key
    PKCS1 formatted private key, which is described by the ASN.1 type:
    RSAPrivateKey ::= SEQUENCE {
          version           Version,
          modulus           INTEGER,  -- n
          publicExponent    INTEGER,  -- e
          privateExponent   INTEGER,  -- d
          prime1            INTEGER,  -- p
          prime2            INTEGER,  -- q
          exponent1         INTEGER,  -- d mod (p-1)
          exponent2         INTEGER,  -- d mod (q-1)
          coefficient       INTEGER,  -- (inverse of q) mod p
          otherPrimeInfos   OtherPrimeInfos OPTIONAL
    }
    """
    return RSA.importKey(decrypt_data(encrypted_private_key, data_key)) 
開發者ID:Keeper-Security,項目名稱:Commander,代碼行數:19,代碼來源:api.py

示例4: get

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def get(self, request, *args, **kwargs):
        dic = dict(keys=[])

        for rsakey in RSAKey.objects.all():
            public_key = RSA.importKey(rsakey.key).publickey()
            dic['keys'].append({
                'kty': 'RSA',
                'alg': 'RS256',
                'use': 'sig',
                'kid': rsakey.kid,
                'n': long_to_base64(public_key.n),
                'e': long_to_base64(public_key.e),
            })

        response = JsonResponse(dic)
        response['Access-Control-Allow-Origin'] = '*'

        return response 
開發者ID:juanifioren,項目名稱:django-oidc-provider,代碼行數:20,代碼來源:views.py

示例5: get_client_alg_keys

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def get_client_alg_keys(client):
    """
    Takes a client and returns the set of keys associated with it.
    Returns a list of keys.
    """
    if client.jwt_alg == 'RS256':
        keys = []
        for rsakey in RSAKey.objects.all():
            keys.append(jwk_RSAKey(key=importKey(rsakey.key), kid=rsakey.kid))
        if not keys:
            raise Exception('You must add at least one RSA Key.')
    elif client.jwt_alg == 'HS256':
        keys = [SYMKey(key=client.client_secret, alg=client.jwt_alg)]
    else:
        raise Exception('Unsupported key algorithm.')

    return keys 
開發者ID:juanifioren,項目名稱:django-oidc-provider,代碼行數:19,代碼來源:token.py

示例6: testEncrypt1

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def testEncrypt1(self):
                for test in self._testData:
                        # Build the key
                        key = RSA.importKey(test[0])
                        # RNG that takes its random numbers from a pool given
                        # at initialization
                        class randGen:
                            def __init__(self, data):
                                self.data = data
                                self.idx = 0
                            def __call__(self, N):
                                r = self.data[self.idx:self.idx+N]
                                self.idx += N
                                return r
                        # The real test
                        cipher = PKCS.new(key, randfunc=randGen(t2b(test[3])))
                        ct = cipher.encrypt(b(test[1]))
                        self.assertEqual(ct, t2b(test[2])) 
開發者ID:haynieresearch,項目名稱:jarvis,代碼行數:20,代碼來源:test_pkcs1_15.py

示例7: load_crypto_session

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def load_crypto_session(self, msl_data=None):
        try:
            self.encryption_key = base64.standard_b64decode(
                msl_data['encryption_key'])
            self.sign_key = base64.standard_b64decode(
                msl_data['sign_key'])
            if not self.encryption_key or not self.sign_key:
                raise MSLError('Missing encryption_key or sign_key')
            self.rsa_key = RSA.importKey(
                base64.standard_b64decode(msl_data['rsa_key']))
        except Exception:  # pylint: disable=broad-except
            common.debug('Generating new RSA keys')
            self.rsa_key = RSA.generate(2048)
            self.encryption_key = None
            self.sign_key = None 
開發者ID:CastagnaIT,項目名稱:plugin.video.netflix,代碼行數:17,代碼來源:default_crypto.py

示例8: rsa_public_from_der_certificate

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def rsa_public_from_der_certificate(certificate):
    # Extract subject_public_key_info field from X.509 certificate (see RFC3280)
    try:
        # try to extract pubkey from scapy.layers.x509 X509Cert type in case
        # der_certificate is of type X509Cert
        # Note: der_certificate may not be of type X509Cert if it wasn't
        # received completely, in that case, we'll try to extract it anyway
        # using the old method.
        # TODO: get rid of the old method and always expect X509Cert obj ?
        return RSA.importKey(str(certificate.tbsCertificate.subjectPublicKeyInfo))
    except AttributeError:
        pass

    # Fallback method, may pot. allow to extract pubkey from incomplete der streams
    cert = DerSequence()
    cert.decode(certificate)

    tbs_certificate = DerSequence()
    tbs_certificate.decode(cert[0])       # first DER SEQUENCE

    # search for pubkey OID: rsaEncryption: "1.2.840.113549.1.1.1"
    # hex: 06 09 2A 86 48 86 F7 0D 01 01 01
    subject_public_key_info = None
    for seq in tbs_certificate:
        if not isinstance(seq, basestring):
            continue     # skip numerics and non sequence stuff
        if "\x2A\x86\x48\x86\xF7\x0D\x01\x01\x01" in seq:
            subject_public_key_info = seq

    if subject_public_key_info is None:
        raise ValueError("could not find OID rsaEncryption 1.2.840.113549.1.1.1 in certificate")

    # Initialize RSA key
    return RSA.importKey(subject_public_key_info) 
開發者ID:tintinweb,項目名稱:scapy-ssl_tls,代碼行數:36,代碼來源:ssl_tls_keystore.py

示例9: from_private

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def from_private(cls, private):
        private = RSA.importKey(private)
        public = private.publickey()
        return cls(public, private) 
開發者ID:tintinweb,項目名稱:scapy-ssl_tls,代碼行數:6,代碼來源:ssl_tls_keystore.py

示例10: setUp

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def setUp(self):
        self.pem_priv_key = """-----BEGIN PRIVATE KEY-----
        MIIEwAIBADANBgkqhkiG9w0BAQEFAASCBKowggSmAgEAAoIBAQDDLrmt4lKRpm6P
        2blptwJsa1EBuxuuAayLjwNqKGvm5c1CAUEa/NtEpUMM8WYKRDwxzakUIGI/BdP3
        NOEMphcs5+OekgJLhzoSdtAIrXPy8JIidENZE6FzCJ2b6fHU5O4hoNvv1Bx5yoZr
        HVaWJIZMRRocJJ0Nf9oMaU8IE6m6OdBzQHEwcnL2/a8Q3VxstHufzjILmaZD9WL+
        6AESlQMKZPNQ+Xd7d4nvnVkY4ZV46tA+KvADGuotgovQwG+uiyQoGRrQUms21vHF
        zIvd3G9OCiyCTCHSyfsE3g7tks33NZ8O8gF8xa9OmU9TQPwwAyUr6JQXz0CW77o7
        Cr9LpHuNAgMBAAECggEBAJRbMbtfqc8XqDYjEfGur2Lld19Pb0yl7RbvD3NjYhDR
        X2DqPyhaRfg5fWubGSp4jyBz6C5qJwMsVN80DFNm83qoj7T52lC6aoOaV6og3V8t
        SIZzxLUyXKdpRxM5kR13HSHmeQYkPbi9HcrRM/1PqdzTMXNuyQl3wq9oZDAJchsf
        fmoh080htkaxhEb1bMXa2Lj7j2OIkHOsQeIu6BdbxIKRPIT+zrcklE6ocW8fTWAS
        Qi3IZ1FYLL+fs6TTxjx0VkC8QLaxWxY0pqTiwS7ndZiZKc3l3ARuvRk8buP+X3Jg
        BD86FQ18OXZC9boMbDbzv2cOLtdkq5pS3lJE4F9gjYECgYEA69ukU2pNWot2OPwK
        PuPwAXWNrvnvFzQgIc0qOiCmgKJU6wqunlop4Bx5XmetHExVyJVBEhaHoDr0F3Rs
        gt8IclKDsWGXoVcgfu3llMimiZ05hOf/XtcGTCZwZenMQ30cFh4ZRuUu7WCZ9tqO
        28P8jCXB3IcaRpRnNvVvmCr5NXECgYEA09nUzRW993SlohceRW2C9fT9HZ4BaPWO
        5wVlnoo5mlUfAyzl+AGT/WlKmrn/1gAHIznQJ8ZIABQvPaBXhvkANXZP5Ie0lObw
        jA7qFuKt7yV4GGlDnU1MOLh+acABMQBGSx8BJDaomH7glTiPEPTZjoP6wfAsd1uv
        Knjt7jH2ad0CgYEAx9ghknRd+rx0fbBBVix4riPW20324ihOmZVnlD0aF6B0Z3tz
        ncUz+irmQ7GBIpsjjIO60QK6BHAvZrhFQVaNp6B26ZORkSlr5WDZyImDYtMPa6fP
        36I+OcPQNOo3I3Acnjj+ne2PJ59Ula92oIudr3pGmv72qpsQIacw2TSAWGECgYEA
        sdNAN+HPMn68ZaGoLDjvW8uIB6tQnay5hhvWn8yA65YV0RGH+7Q/Z9BQ6i3EnPor
        A5uMqUZbu4011jHYJpiuXzHvf/GVWAO92KLQReOCgqHd/Aen1MtEdrwOiG+90Ebd
        ukLNL3ud61tc4oS2OlJ8p48LFm2mtY3FLA6UEYPoxhUCgYEAtsfWIGnBh7XC+HwI
        2higSgN92VpJHSPOyOi0aG/u5AEQ+fsCUIi3KakxzvmiGMAEvWItkKyz2Gu8smtn
        2HVsGxI5UW7aLw9s3qe8kyMSfUk6pGamVhJUQmDr77+5zEzykPBxwGwDwdeR43CR
        xVgf/Neb/avXgIgi6drj8dp1fWA=
        -----END PRIVATE KEY-----
                """
        self.rsa = RSA.importKey(self.pem_priv_key) 
開發者ID:tintinweb,項目名稱:scapy-ssl_tls,代碼行數:33,代碼來源:test_ssl_tls_keystore.py

示例11: rsa_key

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def rsa_key(self):
        """
        Return the RSA key as a Cryptodome.RSA object.
        """
        if not self.secret_key_rsa_private:
            self.secret_key_rsa_private = generate_rsa_key(2048)
            self.save()

        return RSA.importKey(self.secret_key_rsa_private) 
開發者ID:open-craft,項目名稱:opencraft,代碼行數:11,代碼來源:secret_keys.py

示例12: rsa_import_pubkey

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def rsa_import_pubkey(buf):
    return RSA.importKey(buf) 
開發者ID:keylime,項目名稱:keylime,代碼行數:4,代碼來源:cryptodome.py

示例13: rsa_import_privkey

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def rsa_import_privkey(buf,password=None):
    return RSA.importKey(buf,password) 
開發者ID:keylime,項目名稱:keylime,代碼行數:4,代碼來源:cryptodome.py

示例14: parse_PRIK

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def parse_PRIK(chunk, encryption_key):
    """Parse PRIK chunk which contains private RSA key"""
    decrypted = decode_aes256('cbc',
                              encryption_key[:16],
                              decode_hex(chunk.payload),
                              encryption_key)

    hex_key = re.match(br'^LastPassPrivateKey<(?P<hex_key>.*)>LastPassPrivateKey$', decrypted).group('hex_key')
    rsa_key = RSA.importKey(decode_hex(hex_key))

    rsa_key.dmp1 = rsa_key.d % (rsa_key.p - 1)
    rsa_key.dmq1 = rsa_key.d % (rsa_key.q - 1)
    rsa_key.iqmp = number.inverse(rsa_key.q, rsa_key.p)

    return rsa_key 
開發者ID:Keeper-Security,項目名稱:Commander,代碼行數:17,代碼來源:parser.py

示例15: private_to_public_key

# 需要導入模塊: from Cryptodome.PublicKey import RSA [as 別名]
# 或者: from Cryptodome.PublicKey.RSA import importKey [as 別名]
def private_to_public_key(pk_file):
    f = open(pk_file, 'r')
    pk = RSA.importKey(f.read())
    return pk.publickey().exportKey('PEM') 
開發者ID:IdentityPython,項目名稱:SATOSA,代碼行數:6,代碼來源:util.py


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