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


Python pem.readPemBlocksFromFile方法代碼示例

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


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

示例1: test_from_string_pkcs8_extra_bytes

# 需要導入模塊: from pyasn1_modules import pem [as 別名]
# 或者: from pyasn1_modules.pem import readPemBlocksFromFile [as 別名]
def test_from_string_pkcs8_extra_bytes(self):
        key_bytes = PKCS8_KEY_BYTES
        _, pem_bytes = pem.readPemBlocksFromFile(
            six.StringIO(_helpers.from_bytes(key_bytes)),
            _python_rsa._PKCS8_MARKER)

        key_info, remaining = None, 'extra'
        decode_patch = mock.patch(
            'pyasn1.codec.der.decoder.decode',
            return_value=(key_info, remaining),
            autospec=True)

        with decode_patch as decode:
            with pytest.raises(ValueError):
                _python_rsa.RSASigner.from_string(key_bytes)
            # Verify mock was called.
            decode.assert_called_once_with(
                pem_bytes, asn1Spec=_python_rsa._PKCS8_SPEC) 
開發者ID:GoogleCloudPlatform,項目名稱:google-auth-library-python,代碼行數:20,代碼來源:test__python_rsa.py

示例2: from_string

# 需要導入模塊: from pyasn1_modules import pem [as 別名]
# 或者: from pyasn1_modules.pem import readPemBlocksFromFile [as 別名]
def from_string(cls, key, password='notasecret'):
        """Construct an RsaSigner instance from a string.

        Args:
            key: string, private key in PEM format.
            password: string, password for private key file. Unused for PEM
                      files.

        Returns:
            RsaSigner instance.

        Raises:
            ValueError if the key cannot be parsed as PKCS#1 or PKCS#8 in
            PEM format.
        """
        key = _from_bytes(key)  # pem expects str in Py3
        marker_id, key_bytes = pem.readPemBlocksFromFile(
            six.StringIO(key), _PKCS1_MARKER, _PKCS8_MARKER)

        if marker_id == 0:
            pkey = rsa.key.PrivateKey.load_pkcs1(key_bytes,
                                                 format='DER')
        elif marker_id == 1:
            key_info, remaining = decoder.decode(
                key_bytes, asn1Spec=_PKCS8_SPEC)
            if remaining != b'':
                raise ValueError('Unused bytes', remaining)
            pkey_info = key_info.getComponentByName('privateKey')
            pkey = rsa.key.PrivateKey.load_pkcs1(pkey_info.asOctets(),
                                                 format='DER')
        else:
            raise ValueError('No key could be detected.')

        return cls(pkey) 
開發者ID:0x0ece,項目名稱:oscars2016,代碼行數:36,代碼來源:_pure_python_crypt.py

示例3: from_string

# 需要導入模塊: from pyasn1_modules import pem [as 別名]
# 或者: from pyasn1_modules.pem import readPemBlocksFromFile [as 別名]
def from_string(cls, key, password='notasecret'):
        """Construct an RsaSigner instance from a string.

        Args:
            key: string, private key in PEM format.
            password: string, password for private key file. Unused for PEM
                      files.

        Returns:
            RsaSigner instance.

        Raises:
            ValueError if the key cannot be parsed as PKCS#1 or PKCS#8 in
            PEM format.
        """
        key = _helpers._from_bytes(key)  # pem expects str in Py3
        marker_id, key_bytes = pem.readPemBlocksFromFile(
            six.StringIO(key), _PKCS1_MARKER, _PKCS8_MARKER)

        if marker_id == 0:
            pkey = rsa.key.PrivateKey.load_pkcs1(key_bytes,
                                                 format='DER')
        elif marker_id == 1:
            key_info, remaining = decoder.decode(
                key_bytes, asn1Spec=_PKCS8_SPEC)
            if remaining != b'':
                raise ValueError('Unused bytes', remaining)
            pkey_info = key_info.getComponentByName('privateKey')
            pkey = rsa.key.PrivateKey.load_pkcs1(pkey_info.asOctets(),
                                                 format='DER')
        else:
            raise ValueError('No key could be detected.')

        return cls(pkey) 
開發者ID:taers232c,項目名稱:GAMADV-XTD,代碼行數:36,代碼來源:_pure_python_crypt.py

示例4: test_from_string_pkcs8_extra_bytes

# 需要導入模塊: from pyasn1_modules import pem [as 別名]
# 或者: from pyasn1_modules.pem import readPemBlocksFromFile [as 別名]
def test_from_string_pkcs8_extra_bytes(self):
        key_bytes = self._load_pkcs8_key_bytes()
        _, pem_bytes = pem.readPemBlocksFromFile(
            six.StringIO(_helpers._from_bytes(key_bytes)),
            _pure_python_crypt._PKCS8_MARKER)

        with mock.patch('pyasn1.codec.der.decoder.decode') as mock_decode:
            key_info, remaining = None, 'extra'
            mock_decode.return_value = (key_info, remaining)
            with self.assertRaises(ValueError):
                crypt.RsaSigner.from_string(key_bytes)
            # Verify mock was called.
            mock_decode.assert_called_once_with(
                pem_bytes, asn1Spec=_pure_python_crypt._PKCS8_SPEC) 
開發者ID:openstack,項目名稱:deb-python-oauth2client,代碼行數:16,代碼來源:test__pure_python_crypt.py

示例5: from_string

# 需要導入模塊: from pyasn1_modules import pem [as 別名]
# 或者: from pyasn1_modules.pem import readPemBlocksFromFile [as 別名]
def from_string(cls, key, key_id=None):
        """Construct an Signer instance from a private key in PEM format.

        Args:
            key (str): Private key in PEM format.
            key_id (str): An optional key id used to identify the private key.

        Returns:
            google.auth.crypt.Signer: The constructed signer.

        Raises:
            ValueError: If the key cannot be parsed as PKCS#1 or PKCS#8 in
                PEM format.
        """
        key = _helpers.from_bytes(key)  # PEM expects str in Python 3
        marker_id, key_bytes = pem.readPemBlocksFromFile(
            six.StringIO(key), _PKCS1_MARKER, _PKCS8_MARKER)

        # Key is in pkcs1 format.
        if marker_id == 0:
            private_key = rsa.key.PrivateKey.load_pkcs1(
                key_bytes, format='DER')
        # Key is in pkcs8.
        elif marker_id == 1:
            key_info, remaining = decoder.decode(
                key_bytes, asn1Spec=_PKCS8_SPEC)
            if remaining != b'':
                raise ValueError('Unused bytes', remaining)
            private_key_info = key_info.getComponentByName('privateKey')
            private_key = rsa.key.PrivateKey.load_pkcs1(
                private_key_info.asOctets(), format='DER')
        else:
            raise ValueError('No key could be detected.')

        return cls(private_key, key_id=key_id) 
開發者ID:GoogleCloudPlatform,項目名稱:google-auth-library-python,代碼行數:37,代碼來源:_python_rsa.py


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