提交 dab6f095 编写于 作者: B Bodo Möller

Workaround for irrelevant problem.

上级 45206340
...@@ -189,9 +189,10 @@ end: ...@@ -189,9 +189,10 @@ end:
int ssl23_get_client_hello(SSL *s) int ssl23_get_client_hello(SSL *s)
{ {
char buf_space[11]; /* Request this many bytes in initial read. char buf_space[11]; /* Request this many bytes in initial read.
* We can detect SSL 3.0/TLS 1.0 Client Hellos only * We can detect SSL 3.0/TLS 1.0 Client Hellos
* when the following is in a single record * ('type == 3') correctly only when the following
* (not guaranteed by protocol specs): * is in a single record, which is not guaranteed by
* the protocol specification:
* Byte Content * Byte Content
* 0 type \ * 0 type \
* 1/2 version > record header * 1/2 version > record header
...@@ -200,7 +201,6 @@ int ssl23_get_client_hello(SSL *s) ...@@ -200,7 +201,6 @@ int ssl23_get_client_hello(SSL *s)
* 6-8 length > Client Hello message * 6-8 length > Client Hello message
* 9/10 client_version / * 9/10 client_version /
*/ */
/* XXX */
char *buf= &(buf_space[0]); char *buf= &(buf_space[0]);
unsigned char *p,*d,*dd; unsigned char *p,*d,*dd;
unsigned int i; unsigned int i;
...@@ -338,14 +338,23 @@ int ssl23_get_client_hello(SSL *s) ...@@ -338,14 +338,23 @@ int ssl23_get_client_hello(SSL *s)
else if ((p[0] == SSL3_RT_HANDSHAKE) && else if ((p[0] == SSL3_RT_HANDSHAKE) &&
(p[1] == SSL3_VERSION_MAJOR) && (p[1] == SSL3_VERSION_MAJOR) &&
(p[5] == SSL3_MT_CLIENT_HELLO) && (p[5] == SSL3_MT_CLIENT_HELLO) &&
(p[9] == p[1])) ((p[3] == 0 && p[4] < 5 /* silly record length? */)
|| (p[9] == p[1])))
{ {
/* /*
* SSLv3 or tls1 header * SSLv3 or tls1 header
*/ */
/* we must look at client_version inside the client hello: */ v[0]=p[1]; /* major version */
v[0]=p[9]; v[1]=p[10]; /* We must look at client_version inside the Client Hello message
* to get the correct minor version: */
v[1]=p[10];
/* However if we have only a pathologically small fragment of the
* Client Hello message, we simply use the version from the
* record header -- this is incorrect but unlikely to fail in
* practice */
if (p[3] == 0 && p[4] < 6)
v[1]=p[2];
if (v[1] >= TLS1_VERSION_MINOR) if (v[1] >= TLS1_VERSION_MINOR)
{ {
if (!(s->options & SSL_OP_NO_TLSv1)) if (!(s->options & SSL_OP_NO_TLSv1))
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册