go get github.com/gabriel-vasile/mimetype
mtype := mimetype.Detect([]byte) // 或 mtype, err := mimetype.DetectReader(io.Reader) // 或 mtype, err := mimetype.DetectFile("/path/to/file") fmt.Println(mtype.String(), mtype.Extension())
只在万不得已的情况下使用像mimetype这样的库。使用魔数进行内容类型检测速度慢、不准确且非标准。大多数情况下,协议都有指定此类元数据的方法;例如,HTTP和SMTP中的Content-Type
头。
问:我的文件在支持的MIME类型列表中,但未被正确检测。我该怎么办?
答:某些文件格式(通常是Microsoft Office文档)将其签名保存在文件末尾。尝试增加用于检测的字节数:
mimetype.SetLimit(1024*1024) // 将限制设置为1MB。 // 或 mimetype.SetLimit(0) // 无限制,使用整个文件内容。 mimetype.DetectFile("file.doc")
如果增加限制不起作用,请提交问题。
mimetype使用层级结构来保持MIME类型检测逻辑。这减少了检测文件类型所需的调用次数。选择这种结构的原因是有些文件格式用作其他文件格式的容器。例如,Microsoft Office文件只是包含特定元数据文件的zip压缩包。一旦文件被识别为zip,就不需要检查它是否为文本文件,但值得检查它是否为Microsoft Office文件。
为防止将整个文件加载到内存中,当从reader或文件检测时,mimetype仅限于读取输入的头部。
<div align="center"> <img alt="项目结构" src="https://yellow-cdn.veclightyear.com/835a84d5/dda89ac4-b08e-4f31-8569-c07ba64bd0ef.gif" width="88%"> </div>得益于层级结构、优先搜索常见格式以及仅限于文件头部,mimetype的性能与标准库http.DetectContentType
相匹配,同时优于替代包。
mimetype http.DetectContentType filetype BenchmarkMatchTar-24 250 ns/op 400 ns/op 3778 ns/op BenchmarkMatchZip-24 524 ns/op 351 ns/op 4884 ns/op BenchmarkMatchJpeg-24 103 ns/op 228 ns/op 839 ns/op BenchmarkMatchGif-24 139 ns/op 202 ns/op 751 ns/op BenchmarkMatchPng-24 165 ns/op 221 ns/op 1176 ns/op
请参阅CONTRIBUTING.md。
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效 率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。