4 releases

0.1.3 Dec 1, 2024
0.1.2 Jan 12, 2018
0.1.1 Jan 6, 2017
0.1.0 Jan 4, 2017

#476 in Web programming

Download history 1392/week @ 2024-10-01 745/week @ 2024-10-08 1632/week @ 2024-10-15 1996/week @ 2024-10-22 1572/week @ 2024-10-29 1579/week @ 2024-11-05 1178/week @ 2024-11-12 1662/week @ 2024-11-19 2650/week @ 2024-11-26 1956/week @ 2024-12-03 3418/week @ 2024-12-10 4389/week @ 2024-12-17 831/week @ 2024-12-24 2369/week @ 2024-12-31 4085/week @ 2025-01-07 4506/week @ 2025-01-14

12,324 downloads per month
Used in 7 crates (6 directly)

Apache-2.0

41KB
640 lines

mime-sniffer ci crate

Detecting mime types base on content sniffer.

Document

The detection workflow was copied from Chromium

For more detail, please read How Mozilla determines MIME Types.

Usage

To use mime-sniffer, first add this to your Cargo.toml:

[dependencies]
mime-sniffer = "^0.1"

Then, add this to your crate root:

extern crate mime_sniffer;

use mime_sniffer::MimeTypeSniffer;

And then, use hash function with module or hasher

use mime_sniffer::MimeTypeSniffer;

assert_eq!(Some("application/pdf"), b"%PDF-1.5".sniff_mime_type());

Examples

extern crate url;
#[macro_use]
extern crate mime;
extern crate mime_sniffer;

use url::Url;

use mime_sniffer::{HttpRequest, MimeTypeSniffer, MimeTypeSniffable, MimeTypeSnifferExt};

let url = Url::parse("http://localhost/notes.ppt").unwrap();
let req = HttpRequest {
    content: b"\xD0\xCF\x11\xE0\xA1\xB1\x1A\xE1",
    url: &url,
    type_hint: "text/plain",
};

assert!(req.should_sniff_mime_type());
assert_eq!(req.sniff_mime_type(), Some("application/vnd.ms-powerpoint"));
assert_eq!(req.sniff_mime_type_ext().unwrap().type_(), mime::APPLICATION);
  • To recognize binary file type, you may need libmagic with rust binding rust-magic crate. crate
  • To guess MIME type by file extension, you may need mime_guess crate. crate
  • To manage MIME type as strong types, you may need mime.rs crate. crate

Dependencies

~2–3MB
~55K SLoC