1Apache2::Upload(3) User Contributed Perl Documentation Apache2::Upload(3)
2
3
4
6 Apache2::Upload - Methods for dealing with file uploads.
7
9 use Apache2::Upload;
10
11 $req = Apache2::Request->new($r);
12 $upload = $req->upload("foo");
13 $size = $upload->size;
14
15 # three methods to get at the upload's contents ... slurp, fh, io
16
17 $upload->slurp($slurp_data);
18
19 read $upload->fh, $fh_data, $size;
20 ok $slurp_data eq $fh_data;
21
22 my $io = $upload->io;
23 print while <$io>;
24
26 Apache2::Upload is a new module based on the original package included
27 in Apache2::Request 1.X. Users requiring the upload API must now "use
28 Apache2::Upload", which adds the "upload" method to Apache2::Request.
29 Apache2::Upload is largely backwards-compatible with the original 1.X
30 API. See the "PORTING from 1.X" section below for a list of known
31 issues.
32
33 This manpage documents the Apache2::Upload package.
34
36 name
37 $upload->name()
38
39 The name of the HTML form element which generated the upload.
40
41 filename
42 $upload->filename()
43
44 The (client-side) filename as submitted in the HTML form. Note: some
45 agents will submit the file's full pathname, while others may submit
46 just the basename.
47
48 fh
49 $upload->fh()
50
51 Creates filehandle reference to the upload's spooled tempfile, which
52 contains the full contents of the upload.
53
54 io
55 $upload->io()
56
57 Creates a tied IO handle. This method is a more efficient version of
58 "fh", but with "io" the handle ref returned is not seekable. It is
59 tied to an APR::Request::Brigade object, so you may use the brigade API
60 on the tied object if you want to manipulate the IO stream (beyond
61 simply reading from it).
62
63 The returned reference is actually an object which has "read" and
64 "readline" methods available. However these methods are just syntactic
65 sugar for the underlying "READ" and "READLINE" methods from
66 APR::Request::Brigade.
67
68 $io = $upload->io;
69 print while $io->read($_); # equivalent to: tied(*$io)->READ($_)
70
71 See READ and READLINE below for additional notes on their usage.
72
73 bb
74 $upload->bb()
75 $upload->bb($set)
76
77 Get/set the APR::Brigade which represents the upload's contents.
78
79 size
80 $upload->size()
81
82 Returns the size of the upload in bytes.
83
84 info
85 $upload->info()
86 $upload->info($set)
87
88 Get/set the additional header information table for the uploaded file.
89 Returns a hash reference tied to the APR::Table class. An optional
90 $table argument can be passed to reassign the upload's internal
91 (apr_table_t) info table to the one $table represents.
92
93 my $info = $upload->info;
94 while (my($hdr_name, $hdr_value) = each %$info) {
95 # ...
96 }
97
98 # fetch upload's Content-Type header
99 my $type = $upload->info->{"Content-type"};
100
101 type
102 $upload->type()
103
104 Returns the MIME type of the given Apache2::Upload object.
105
106 my $type = $upload->type;
107
108 #same as
109 my $content_type = $upload->info->{"Content-Type"};
110 $content_type =~ s/;.*$//ms;
111
112 link
113 $upload->link()
114
115 To avoid recopying the upload's internal tempfile brigade on a
116 *nix-like system, link will create a hard link to it:
117
118 my $upload = $req->upload('foo');
119 $upload->link("/path/to/newfile") or
120 die sprintf "link from '%s' failed: $!", $upload->tempname;
121
122 Typically the new name must lie on the same device and partition as the
123 brigade's tempfile. If this or any other reason prevents the OS from
124 linking the files, "link()" will instead copy the temporary file to the
125 specified location.
126
127 slurp
128 $upload->slurp($contents)
129
130 Reads the full contents of a file upload into the scalar argument. The
131 return value is the length of the file.
132
133 my $size = $upload->slurp($contents);
134
135 tempname
136 $upload->tempname()
137
138 Provides the name of the spool file.
139
140 my $tempname = $upload->tempname;
141
143 This class is derived from APR::Brigade, providing additional methods
144 for TIEHANDLE, READ and READLINE. To be memory efficient, these
145 methods delete buckets from the brigade as soon as their data is
146 actually read, so you cannot "seek" on handles tied to this class.
147 Such handles have semantics similar to that of a read-only socket.
148
149 TIEHANDLE
150 APR::Request::Brigade->TIEHANDLE($bb)
151
152 Creates a copy of the bucket brigade represented by $bb, and blesses
153 that copy into the APR::Request::Brigade class. This provides
154 syntactic sugar for using perl's builtin "read", "readline", and "<>"
155 operations on handles tied to this package:
156
157 use Symbol;
158 $fh = gensym;
159 tie *$fh, "APR::Request:Brigade", $bb;
160 print while <$fh>;
161
162 READ
163 $bb->READ($contents)
164 $bb->READ($contents, $length)
165 $bb->READ($contents, $length, $offset)
166
167 Reads data from the brigade $bb into $contents. When omitted $length
168 defaults to "-1", which reads the first bucket into $contents. A
169 positive $length will read in $length bytes, or the remainder of the
170 brigade, whichever is greater. $offset represents the index in $context
171 to read the new data.
172
173 READLINE
174 $bb->READLINE()
175
176 Returns the first line of data from the bride. Lines are terminated by
177 linefeeds (the '\012' character), but we may eventually use $/ instead.
178
180 • "$upload->next()" is no longer available; please use the
181 "APR::Request::Param::Table" API when iterating over upload
182 entries.
183
184 • "info($header_name)" is replaced by "info($set)".
185
186 • "type()" returns only the MIME-type portion of the Content-Type
187 header.
188
190 APR::Request::Param::Table, APR::Request::Error, Apache2::Request,
191 APR::Table(3)
192
194 Licensed to the Apache Software Foundation (ASF) under one or more
195 contributor license agreements. See the NOTICE file distributed with
196 this work for additional information regarding copyright ownership.
197 The ASF licenses this file to You under the Apache License, Version 2.0
198 (the "License"); you may not use this file except in compliance with
199 the License. You may obtain a copy of the License at
200
201 http://www.apache.org/licenses/LICENSE-2.0
202
203 Unless required by applicable law or agreed to in writing, software
204 distributed under the License is distributed on an "AS IS" BASIS,
205 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
206 See the License for the specific language governing permissions and
207 limitations under the License.
208
209
210
211perl v5.32.1 2021-05-15 Apache2::Upload(3)