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


Python PrivateCertificate.load方法代碼示例

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


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

示例1: setUp

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import load [as 別名]
    def setUp(self):
        """
        Create a L{PantheonHTTPChecker} pointed at a mock authentication service
        with some simple site and user information.
        """
        self.site = 'example.com'
        self.cwd = '/some/path'
        self.uid = 1542
        self.username = 'alice'
        self.password = 'correct password'
        keyString = FilePath(__file__).sibling('id_rsa').getContent()
        self.privateKey = Key.fromString(keyString)

        caKeyString = FilePath(__file__).sibling('cakey.pem').getContent()
        self.caKey = KeyPair.load(caKeyString, FILETYPE_PEM)
        caCertString = FilePath(__file__).sibling('cacert.pem').getContent()
        self.caCert = PrivateCertificate.load(
            caCertString, self.caKey, FILETYPE_PEM)

        self.resource = MockPantheonAuthResource(
            sites={self.site: [self.username]},
            authorizations={self.site: dict(cwd=self.cwd, uid=self.uid)},
            passwords={self.username: self.password},
            keys={self.username: self.privateKey},
            )
        self.server = MockPantheonAuthServer(
            reactor, self.resource, self.caCert)
        self.server.startService()
        self.addCleanup(self.server.stopService)
開發者ID:exarkun,項目名稱:Pantheon-SSH,代碼行數:31,代碼來源:fakebackend.py

示例2: getServerContext

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import load [as 別名]
    def getServerContext(self):
        """
        Generate a new L{OpenSSL.SSL.Context} object configured to use a
        certificate signed by C{self.ca} and only accept connections from peers
        which are also using a certificate signed by C{self.ca}.
        """
        # Generate a new key for the server and have the CA sign a certificate
        # for it.
        key = KeyPair.generate(size=512)
        req = key.certificateRequest(DN(commonName='localhost'))
        certData = self.ca.signCertificateRequest(req, lambda dn: True, 1)
        cert = PrivateCertificate.load(certData, key)

        # Use the new key/certificate
        context = Context(TLSv1_METHOD)
        context.use_privatekey(key.original)
        context.use_certificate(cert.original)
        context.check_privatekey()

        # Allow peer certificates signed by the CA
        store = context.get_cert_store()
        store.add_cert(self.ca.original)

        # Verify the peer certificate and require that they have one.
        def verify(conn, cert, errno, depth, preverify_ok):
            return preverify_ok
        context.set_verify(VERIFY_PEER | VERIFY_FAIL_IF_NO_PEER_CERT, verify)
        return context
開發者ID:exarkun,項目名稱:Pantheon-SSH,代碼行數:30,代碼來源:fakebackend.py

示例3: getServerContext

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import load [as 別名]
 def getServerContext(self):
     """
     Return a new SSL context suitable for use in a test server.
     """
     pem = self._pem.getContent()
     cert = PrivateCertificate.load(
         pem, KeyPair.load(pem, FILETYPE_PEM), FILETYPE_PEM)
     return cert.options()
開發者ID:12019,項目名稱:OpenWrt_Luci_Lua,代碼行數:10,代碼來源:test_tls.py

示例4: getServerContext

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import load [as 別名]
 def getServerContext(self):
     """
     Return a new SSL context suitable for use in a test server.
     """
     cert = PrivateCertificate.load(
         self._certificateText,
         KeyPair.load(self._privateKeyText, FILETYPE_PEM),
         FILETYPE_PEM)
     return cert.options()
開發者ID:Almad,項目名稱:twisted,代碼行數:11,代碼來源:test_tls.py

示例5: import

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import load [as 別名]
"""

from twisted.internet.protocol import ServerFactory
from twisted.internet.endpoints import SSL4ClientEndpoint
from twisted.internet.ssl import (
    DN, KeyPair, PrivateCertificate, CertificateOptions)
from twisted.protocols.wire import Echo

from tcp_throughput import Client, driver

# Generate a new self-signed certificate
key = KeyPair.generate(size=2048)
req = key.certificateRequest(DN(commonName='localhost'), digestAlgorithm='sha1')
cert = PrivateCertificate.load(
    key.signCertificateRequest(
        DN(commonName='localhost'), req,
        lambda dn: True, 1, digestAlgorithm='sha1'),
    key)


def main(reactor, duration):
    chunkSize = 16384

    server = ServerFactory()
    server.protocol = Echo
    port = reactor.listenSSL(0, server, cert.options())
    client = Client(
        reactor,
        SSL4ClientEndpoint(
            reactor, '127.0.0.1', port.getHost().port,
            CertificateOptions(
開發者ID:AlekSi,項目名稱:twisted-benchmarks,代碼行數:33,代碼來源:ssl_throughput.py


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