#rustls #byte #tls #fingerprint #ja3 #extract #slice

ja3-rustls

从字节数组中提取 JA3 TLS 指纹,与 Rustls 类型一起工作

5 个版本

0.0.5 2022 年 9 月 17 日
0.0.3 2022 年 9 月 16 日
0.0.2 2022 年 9 月 15 日
0.0.1 2022 年 9 月 14 日
0.0.0 2022 年 9 月 14 日

#24 in #fingerprint

MIT 许可证

27KB
544

使用 Rustls 类型进行 JA3

示例

从字节数组中提取 JA3 TLS 指纹

use ja3_rustls::{parse_tls_plain_message, TlsMessageExt, Ja3Extractor};
use hex_literal::hex;

let buf = hex!("16030100f5010000f10303ad8e0c8dfe3adbc045e51aee4cb9480c02d5da4a240f95e8282a1f51be34901a20681af80b44c4b359adb3f9543a966e07e6ba6bed551472a62cd4b107cbd40e830014130213011303c02cc02bcca9c030c02fcca800ff01000094002b00050403040303000b00020100000a00080006001d00170018000d00140012050304030807080608050804060105010401001700000005000501000000000000001800160000137777772e706574616c7365617263682e636f6d00120000003300260024001d0020086fffef5fa7f04fb7d788615bc425820eba366ddb5f75c7d8336a0a05722d38002d0002010100230000");
let chp = parse_tls_plain_message(&buf)
  .ok()
  .and_then(|message| message.into_client_hello_payload())
  .expect("Message valid");
println!("{:?}", chp.ja3());
println!("{}", chp.ja3());
println!("{}", chp.ja3_with_real_version());
assert_eq!(chp.ja3().to_string(), "771,4866-4865-4867-49196-49195-52393-49200-49199-52392-255,43-11-10-13-23-5-0-18-51-45-35,29-23-24,0");

要生成 JA3 的十六进制字符串,通过 Cargo.toml 激活可选功能

# in Cargo.toml
# under [dependencies]
ja3-rustls = { version = "0.0.0", features = ["md5-string"] } # or just md5

, 然后是

println!("{:x?}", chp.ja3().to_md5()); // requires feature: md5
println!("{}", chp.ja3().to_md5_string()); // requires feature: md5-string

依赖关系

~7–17MB
~300K SLoC