matchit

matchit

Rust实现的快速URL路由匹配库

matchit是一个Rust编写的URL路由匹配库。它支持动态路由段和参数捕获,并通过基数树实现高效路由查找。在benchmark测试中,matchit能在200纳秒内完成复杂路由匹配,性能优于多数同类库。这个开源项目适合需要高性能URL路由的Web应用和API服务使用。

matchitURL路由高性能零拷贝参数匹配Github开源项目

matchit

<img alt="crates.io" src="https://img.shields.io/crates/v/matchit?style=for-the-badge" height="25"> <img alt="github" src="https://img.shields.io/badge/github-matchit-blue?style=for-the-badge" height="25"> <img alt="docs.rs" src="https://img.shields.io/docsrs/matchit?style=for-the-badge" height="25">

一个高性能、零拷贝的URL路由器。

use matchit::Router; fn main() -> Result<(), Box<dyn std::error::Error>> { let mut router = Router::new(); router.insert("/home", "欢迎!")?; router.insert("/users/{id}", "一个用户")?; let matched = router.at("/users/978")?; assert_eq!(matched.params.get("id"), Some("978")); assert_eq!(*matched.value, "一个用户"); Ok(()) }

参数

路由器支持动态路由段。这些可以是命名参数或通配符参数。

/{id}这样的命名参数可以匹配任何内容,直到下一个/或路径末尾。请注意,命名参数后面必须跟着/或路由的末尾。目前不支持动态后缀。

let mut m = Router::new(); m.insert("/users/{id}", true)?; assert_eq!(m.at("/users/1")?.params.get("id"), Some("1")); assert_eq!(m.at("/users/23")?.params.get("id"), Some("23")); assert!(m.at("/users").is_err());

通配符参数以*开头,匹配路径末尾的任何内容。它们必须始终位于路由的末尾

let mut m = Router::new(); m.insert("/{*p}", true)?; assert_eq!(m.at("/foo.js")?.params.get("p"), Some("foo.js")); assert_eq!(m.at("/c/bar.css")?.params.get("p"), Some("c/bar.css")); // 注意,这不会匹配 assert!(m.at("/").is_err());

字面字符{}可以通过使用相同的字符进行转义来包含在静态路由中。例如,{字符用{{转义,}字符用}}转义。

let mut m = Router::new(); m.insert("/{{hello}}", true)?; m.insert("/{hello}", true)?; // 匹配静态路由 assert!(m.at("/{hello}")?.value); // 匹配动态路由 assert_eq!(m.at("/hello")?.params.get("hello"), Some("hello"));

路由优先级

允许静态和动态路由段重叠。如果它们重叠,静态段将被赋予更高的优先级:

let mut m = Router::new(); m.insert("/", "欢迎!").unwrap(); // 优先级:1 m.insert("/about", "关于我").unwrap(); // 优先级:1 m.insert("/{*filepath}", "...").unwrap(); // 优先级:2

它是如何工作的?

路由器利用了URL路由通常遵循层次结构的事实。路由被存储在一个大量使用共同前缀的基数树中。

优先级 路径 值 9 \ 1 3 ├s 无 2 |├earch\ 2 1 |└upport\ 3 2 ├blog\ 4 1 | └{post} 无 1 | └\ 5 2 ├about-us\ 6 1 | └team\ 7 1 └contact\ 8

这使我们可以将路由搜索减少到少量的分支。同一层级的子节点也按注册值的子节点数量进行优先级排序,增加了第一次尝试就选择正确分支的机会。

基准测试

事实证明,这种路由方法非常快。在一个将4个路径与130个注册路由进行匹配的基准测试中,matchit能在200纳秒内找到正确的路由,比大多数其他路由器快一个数量级。你可以在这里查看基准测试代码。

比较路由器/matchit 时间: [175.96 ns 176.39 ns 176.84 ns] 比较路由器/actix 时间: [26.805 us 26.811 us 26.816 us] 比较路由器/path-tree 时间: [468.95 ns 470.34 ns 471.65 ns] 比较路由器/regex 时间: [22.539 us 22.584 us 22.639 us] 比较路由器/route-recognizer 时间: [3.7552 us 3.7732 us 3.8027 us] 比较路由器/routefinder 时间: [5.7313 us 5.7405 us 5.7514 us]

致谢

这个包中的大量代码基于Julien Schmidt的httprouter

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多