1Email::MIME::ContentTypUes(e3r)Contributed Perl DocumentEamtaiioln::MIME::ContentType(3)
2
3
4

NAME

6       Email::MIME::ContentType - Parse a MIME Content-Type or
7       Content-Disposition Header
8

VERSION

10       version 1.022
11

SYNOPSIS

13         use Email::MIME::ContentType;
14
15         # Content-Type: text/plain; charset="us-ascii"; format=flowed
16         my $ct = 'text/plain; charset="us-ascii"; format=flowed';
17         my $data = parse_content_type($ct);
18
19         $data = {
20           type       => "text",
21           subtype    => "plain",
22           attributes => {
23             charset => "us-ascii",
24             format  => "flowed"
25           }
26         };
27
28
29         # Content-Type: application/x-stuff;
30         #  title*0*=us-ascii'en'This%20is%20even%20more%20;
31         #  title*1*=%2A%2A%2Afun%2A%2A%2A%20;
32         #  title*2="isn't it!"
33         my $ct = q(application/x-stuff;
34          title*0*=us-ascii'en'This%20is%20even%20more%20;
35          title*1*=%2A%2A%2Afun%2A%2A%2A%20;
36          title*2="isn't it!");
37         my $data = parse_content_type($ct);
38
39         $data = {
40           type       => "application",
41           subtype    => "x-stuff",
42           attributes => {
43             title => "This is even more ***fun*** isn't it!"
44           }
45         };
46
47         # Content-Disposition: attachment; filename=genome.jpeg;
48         #   modification-date="Wed, 12 Feb 1997 16:29:51 -0500"
49         my $cd = q(attachment; filename=genome.jpeg;
50           modification-date="Wed, 12 Feb 1997 16:29:51 -0500");
51         my $data = parse_content_disposition($cd);
52
53         $data = {
54           type       => "attachment",
55           attributes => {
56             filename            => "genome.jpeg",
57             "modification-date" => "Wed, 12 Feb 1997 16:29:51 -0500"
58           }
59         };
60

FUNCTIONS

62   parse_content_type
63       This routine is exported by default.
64
65       This routine parses email content type headers according to section 5.1
66       of RFC 2045 and also RFC 2231 (Character Set and Parameter
67       Continuations).  It returns a hash as above, with entries for the
68       "type", the "subtype", and a hash of "attributes".
69
70       For backward compatibility with a really unfortunate misunderstanding
71       of RFC 2045 by the early implementors of this module, "discrete" and
72       "composite" are also present in the returned hashref, with the values
73       of "type" and "subtype" respectively.
74
75   parse_content_disposition
76       This routine is exported by default.
77
78       This routine parses email Content-Disposition headers according to RFC
79       2183 and RFC 2231.  It returns a hash as above, with entries for the
80       "type", and a hash of "attributes".
81

WARNINGS

83       This is not a valid content-type header, according to both RFC 1521 and
84       RFC 2045:
85
86         Content-Type: type/subtype;
87
88       If a semicolon appears, a parameter must.  "parse_content_type" will
89       carp if it encounters a header of this type, but you can suppress this
90       by setting $Email::MIME::ContentType::STRICT_PARAMS to a false value.
91       Please consider localizing this assignment!
92
93       Same applies for "parse_content_disposition".
94

AUTHORS

96       ·   Simon Cozens <simon@cpan.org>
97
98       ·   Casey West <casey@geeknest.com>
99
100       ·   Ricardo SIGNES <rjbs@cpan.org>
101

CONTRIBUTORS

103       ·   Matthew Green <mrg@eterna.com.au>
104
105       ·   Pali <pali@cpan.org>
106
107       ·   Thomas Szukala <ts@abusix.com>
108
110       This software is copyright (c) 2004 by Simon Cozens.
111
112       This is free software; you can redistribute it and/or modify it under
113       the same terms as the Perl 5 programming language system itself.
114
115
116
117perl v5.30.1                      2020-01-29       Email::MIME::ContentType(3)
Impressum