我正在尝试阅读 TLS 消息。具体来说,具有证书详细信息的那个(handshake_type = 11)。我正在做的是首先检查消息是否包含Raw
. 如果是这样,我将像这样提取有效负载:b = bytes(pkt[Raw].load)
. 接下来,我正在检查第一个字节是否0x16
为正确的 TLS 版本,接下来的两个字节是否为正确的 TLS 版本。
问题是这条消息没有通过这些条件。WireShark 向我展示了\x16\x03\x03
位置的字节0000
(图片已附上),但我想这是为了方便起见。
那么我假设有效载荷必须以0x16
错误开头吗?
PS
我不想使用scapy-ssl_tls
图书馆。
编辑
这是代码:
def handle_tls_packet(pkt):
if pkt.haslayer(Raw):
b = bytes(pkt[Raw].load)
if b[0] == 0x16:
version = int.from_bytes(b[1:3], 'big')
message_len = int.from_bytes(b[3:5], 'big')
handshake_type = b[5]
handshake_length = int.from_bytes(b[6:9], 'big')
print("v = ", version, " len = ", message_len, " htype =", handshake_type
, "hlen =", handshake_length)
if handshake_type == 11:
# never happens - Why?
certs_len = int.from_bytes(b[7:11], 'big')
EDIT2:
根据Cukic0d的建议,我使用了load_layer("ssl")
.
显然,pkt[TLS].msg
是一个列表(在一个数据包中保存多个 TLS 消息?)。无论如何,我打印了每条此类消息的类型,如下所示:
def handle_tls_packet(pkt):
for tls_msg in pkt[TLS].msg:
print(type(tls_msg))
我期待看到一个TLSCertificate
物体,但从未见过这样的物体。为什么?
EDIT3:如果这会让生活更轻松,
我愿意使用。scapy-ssl_tls