mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-07 09:10:57 +01:00
Avoid ClientHello size bug
As described in #1113, some servers will fail if the length of the ClientHello message is 522, 778, 1034, ... bytes (i.e., if length mod 256 = 10) or 526, 782, 1038, ... bytes (i.e., if length mod 256 = 14). This commit avoid this issue for normal testing by adding a 5-byte padding extension to the message if the length would otherwise be one of these lengths.
This commit is contained in:
parent
15261b2cf4
commit
bc3a812de4
@ -11841,6 +11841,13 @@ socksend_tls_clienthello() {
|
|||||||
done
|
done
|
||||||
len_extension=$len_extension+$len_padding_extension+0x4
|
len_extension=$len_extension+$len_padding_extension+0x4
|
||||||
len_extension_hex=$(printf "%02x\n" $len_extension)
|
len_extension_hex=$(printf "%02x\n" $len_extension)
|
||||||
|
elif [[ ! "$extra_extensions_list" =~ " 0015 " ]] && ( [[ $((len_all%256)) -eq 10 ]] || [[ $((len_all%256)) -eq 14 ]] ); then
|
||||||
|
# Some servers fail if the length of the ClientHello is 522, 778, 1034, 1290, ... bytes.
|
||||||
|
# A few servers also fail if the length is 526, 782, 1038, 1294, ... bytes.
|
||||||
|
# So, if the ClientHello would be one of these length, add a 5-byte padding extension.
|
||||||
|
all_extensions="$all_extensions\\x00\\x15\\x00\\x01\\x00"
|
||||||
|
len_extension+=5
|
||||||
|
len_extension_hex=$(printf "%02x\n" $len_extension)
|
||||||
fi
|
fi
|
||||||
len2twobytes "$len_extension_hex"
|
len2twobytes "$len_extension_hex"
|
||||||
all_extensions="
|
all_extensions="
|
||||||
|
Loading…
Reference in New Issue
Block a user