Crate ja3_rustls
source · [−]Expand description
JA3 with Rustls types
Example
Extract JA3 TLS fingerprint from a slice of bytes:
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");
To generate hex string of JA3, activating optional features via Cargo.toml:
ja3-rustls = { version = "0.0.0", features = ["md5-string"] } # or just md5
, then
ⓘ
println!("{:x?}", chp.ja3().to_md5()); // requires feature: md5
println!("{}", chp.ja3().to_md5_string()); // requires feature: md5-string
Structs
JA3, as explained in [https://github.com/salesforce/ja3]
Ja3
and more fields.A message with decoded payload
Constants
These values are reserved as GREASE values for PskKeyExchangeModes:
These values, when interpreted as big-endian u8 tuples, are reserved GREASE values for cipher
suites and Application-Layer Protocol Negotiation (ALPN).
When interpreted as u16, are reserved GREASE values for extensions, named groups,
signature algorithms, and versions:
Traits
Functions
Generate a random GREASE value.
Generate a random GREASE value.
Try to rewrite a GREASE value with a randomly generated one iff it is actally GREASE.
Otherwise, the value is retuned as is.
Try to rewrite a GREASE value with a randomly generated one iff it is actally GREASE.
Otherwise, the value is retuned as is.