QSslPreSharedKeyAuthenticator露
- PyQt5.QtNetwork.QSslPreSharedKeyAuthenticator
Description露
The QSslPreSharedKeyAuthenticator class provides authentication data for pre shared keys (PSK) ciphersuites.
The QSslPreSharedKeyAuthenticator class is used by an SSL socket to provide the required authentication data in a pre shared key (PSK) ciphersuite.
In a PSK handshake, the client must derive a key, which must match the key set on the server. The exact algorithm of deriving the key depends on the application; however, for this purpose, the server may send an identity hint to the client. This hint, combined with other information (for instance a passphrase), is then used by the client to construct the shared key.
The QSslPreSharedKeyAuthenticator provides means to client applications for completing the PSK handshake. The client application needs to connect a slot to the QSslSocket::preSharedKeyAuthenticationRequired() signal:
# connect(socket, &QSslSocket::preSharedKeyAuthenticationRequired,
# this, &AuthManager::handlePreSharedKeyAuthentication);
The signal carries a QSslPreSharedKeyAuthenticator object containing the identity hint the server sent to the client, and which must be filled with the corresponding client identity and the derived key:
# void AuthManager::handlePreSharedKeyAuthentication(QSslPreSharedKeyAuthenticator *authenticator)
# {
# authenticator->setIdentity("My Qt App");
# const QByteArray key = deriveKey(authenticator->identityHint(), passphrase);
# authenticator->setPreSharedKey(key);
# }
Note: PSK ciphersuites are supported only when using OpenSSL 1.0.1 (or greater) as the SSL backend.
See also
Methods露
- __init__()
Constructs a default QSslPreSharedKeyAuthenticator object.
The identity hint, the identity and the key will be initialized to empty byte arrays; the maximum length for both the identity and the key will be initialized to 0.
- __init__(QSslPreSharedKeyAuthenticator)
Constructs a QSslPreSharedKeyAuthenticator object as a copy of authenticator.
See also
operator=().
- __eq__(QSslPreSharedKeyAuthenticator) → bool
TODO
- identity() → QByteArray
Returns the PSK client identity.
See also
- identityHint() → QByteArray
TODO
- maximumIdentityLength() → int
Returns the maximum length, in bytes, of the PSK client identity.
Note: it is possible to set an identity whose length is greater than ; in this case, only the first bytes will be actually sent to the server.
See also
- maximumPreSharedKeyLength() → int
Returns the maximum length, in bytes, of the pre shared key.
Note: it is possible to set a key whose length is greater than the ; in this case, only the first bytes will be actually sent to the server.
See also
- __ne__(QSslPreSharedKeyAuthenticator) → bool
TODO
- preSharedKey() → QByteArray
Returns the pre shared key.
See also
- setIdentity(Union[QByteArray, bytes, bytearray])
Sets the PSK client identity (to be advised to the server) to identity.
Note: it is possible to set an identity whose length is greater than maximumIdentityLength(); in this case, only the first maximumIdentityLength() bytes will be actually sent to the server.
See also
- setPreSharedKey(Union[QByteArray, bytes, bytearray])
Sets the pre shared key to preSharedKey.
Note: it is possible to set a key whose length is greater than the maximumPreSharedKeyLength(); in this case, only the first maximumPreSharedKeyLength() bytes will be actually sent to the server.
See also
- swap(QSslPreSharedKeyAuthenticator)
TODO