JSON-Threat-Protection: 检测非常规 JSON Payload 的高性能 Rust 库

查看 18|回复 0
作者:C137Rick   
GitHub: https://github.com/ADD-SP/json-threat-protection.rs
JSON 是目前 API 交互的常见数据格式,其灵活的特点也方便构造出一些非常规的数据来影响业务服务:
  • 高度嵌套的 JSON 可能会导致栈溢出
  • 巨大的 Object/Array/String 可能会消耗过多的内存。
  • 同一个 Object 里重复的 Key 可能会对一些敏感业务带来风险。

    总之,即使是一个合法的 JSON 字符串,也可以精心构造出一些 Payload 来影响业务。
    JSON-threat-protection.rs 是一个高性能的 Rust 库来处理不受信任的 JSON 输入并检查上述约束。
    典型应用场景是作为部署在流量入口来提前拒绝非常规的请求。
    测试覆盖
    本项目除了常规的功能测试,还通过了长期的模糊测试( Fuzzing )以确保可以正确处理不受信任的输入。同时最大程度保持了和 serde_json 的行为一致性。
    性能
    [td]Dataset[/td]
    [td]Size[/td]
    [td]serde_json + Validation[/td]
    [td]json-threat-protection[/td]
    [td]Faster[/td]
    [td]Comment[/td]
    kernel_stargazers.json
    1.2M
    12.996 ms
    8.8530 ms
    1.46x
    1000 stargazers JSON information from torvalds/linux
    kernel_stargazers_small.json
    568K
    5.8825 ms
    3.7504 ms
    1.56x
    472 stargazers JSON information from torvalds/linux
    kernel_commits.json
    4.6M
    45.059 ms
    29.682 ms
    1.51x
    1000 commits JSON infomation from torvalds/linux
    tokio_issues.json
    5.1M
    61.935 ms
    33.959 ms
    1.82x
    1000 issues JSON information from tokio-rs/tokio
    tokio_forks.json
    6.1M
    90.984 ms
    45.686 ms
    1.99x
    1000 forks JSON information from tokio-rs/tokio
    tokio_workflow_runs.json
    15M
    221.89 ms
    103.65 ms
    2.14x
    1000 workflow runs JSON information from tokio-rs/tokio
    更多细节见 GitHub 。
    HackerNews
    如果你觉得这个项目不错,欢迎也来 HackerNews 支持一下本项目。
  • 您需要登录后才可以回帖 登录 | 立即注册

    返回顶部