提交 a03a9dbe 编写于 作者: M Matt Caswell

Fix SSL_VERIFY_CLIENT_ONCE

The flag SSL_VERIFY_CLIENT_ONCE is documented as follows:

  B<Server mode:> only request a client certificate on the initial TLS/SSL
  handshake. Do not ask for a client certificate again in case of a
  renegotiation. This flag must be used together with SSL_VERIFY_PEER.

  B<Client mode:> ignored

But the implementation actually did nothing. After the server sends its
ServerKeyExchange message, the code was checking s->session->peer to see if
it is NULL. If it was set then it did not ask for another client
certificate. However s->session->peer will only be set in the event of a
resumption, but a ServerKeyExchange message is only sent in the event of a
full handshake (i.e. no resumption).

The documentation suggests that the original intention was for this to
have an effect on renegotiation, and resumption doesn't come into it.

The fix is to properly check for renegotiation, not whether there is already
a client certificate in the session.

As far as I can tell this has been broken for a *long* time.
Reviewed-by: NRichard Levitte <levitte@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/1982)
上级 a6fd7c1d
...@@ -353,7 +353,7 @@ static int send_certificate_request(SSL *s) ...@@ -353,7 +353,7 @@ static int send_certificate_request(SSL *s)
* if SSL_VERIFY_CLIENT_ONCE is set, don't request cert * if SSL_VERIFY_CLIENT_ONCE is set, don't request cert
* during re-negotiation: * during re-negotiation:
*/ */
&& ((s->session->peer == NULL) || && (s->s3->tmp.finish_md_len == 0 ||
!(s->verify_mode & SSL_VERIFY_CLIENT_ONCE)) !(s->verify_mode & SSL_VERIFY_CLIENT_ONCE))
/* /*
* never request cert in anonymous ciphersuites (see * never request cert in anonymous ciphersuites (see
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册