1docs::api::Apache2::ResUpsoenrseC(o3n)tributed Perl Docudmoecnst:a:taipoin::Apache2::Response(3)
2
3
4
6 Apache2::Response - Perl API for Apache HTTP request response methods
7
9 use Apache2::Response ();
10
11 $r->custom_response(Apache2::Const::FORBIDDEN, "No Entry today");
12
13 $etag = $r->make_etag($force_weak);
14 $r->set_etag();
15 $status = $r->meets_conditions();
16
17 $mtime_rat = $r->rationalize_mtime($mtime);
18 $r->set_last_modified($mtime);
19 $r->update_mtime($mtime);
20
21 $r->send_cgi_header($buffer);
22
23 $r->set_content_length($length);
24
25 $ret = $r->set_keepalive();
26
28 "Apache2::Response" provides the Apache request object utilities API
29 for dealing with HTTP response generation process.
30
32 "Apache2::Response" provides the following functions and/or methods:
33
34 "custom_response"
35 Install a custom response handler for a given status
36
37 $r->custom_response($status, $string);
38
39 obj: $r ( "Apache2::RequestRec object" )
40 The current request
41
42 arg1: $status ( "Apache2::Const constant" )
43 The status for which the custom response should be used (e.g.
44 "Apache2::Const::AUTH_REQUIRED")
45
46 arg2: $string (string)
47 The custom response to use. This can be a static string, or a URL,
48 full or just the uri path (/foo/bar.txt).
49
50 ret: no return value
51 since: 2.0.00
52
53 "custom_response()" doesn't alter the response code, but is used to
54 replace the standard response body. For example, here is how to change
55 the response body for the access handler failure:
56
57 package MyApache2::MyShop;
58 use Apache2::Response ();
59 use Apache2::Const -compile => qw(FORBIDDEN OK);
60 sub access {
61 my $r = shift;
62
63 if (MyApache2::MyShop::tired_squirrels()) {
64 $r->custom_response(Apache2::Const::FORBIDDEN,
65 "It's siesta time, please try later");
66 return Apache2::Const::FORBIDDEN;
67 }
68
69 return Apache2::Const::OK;
70 }
71 ...
72
73 # httpd.conf
74 PerlModule MyApache2::MyShop
75 <Location /TestAPI__custom_response>
76 AuthName dummy
77 AuthType none
78 PerlAccessHandler MyApache2::MyShop::access
79 PerlResponseHandler MyApache2::MyShop::response
80 </Location>
81
82 When squirrels can't run any more, the handler will return 403, with
83 the custom message:
84
85 It's siesta time, please try later
86
87 "make_etag"
88 Construct an entity tag from the resource information. If it's a real
89 file, build in some of the file characteristics.
90
91 $etag = $r->make_etag($force_weak);
92
93 obj: $r ( "Apache2::RequestRec object" )
94 The current request
95
96 arg1: $force_weak (number)
97 Force the entity tag to be weak - it could be modified again in as
98 short an interval.
99
100 ret: $etag (string)
101 The entity tag
102
103 since: 2.0.00
104
105 "meets_conditions"
106 Implements condition "GET" rules for HTTP/1.1 specification. This
107 function inspects the client headers and determines if the response
108 fulfills the specified requirements.
109
110 $status = $r->meets_conditions();
111
112 obj: $r ( "Apache2::RequestRec object" )
113 The current request
114
115 ret: $status ( "Apache2::Const status constant" )
116 "Apache2::Const::OK" if the response fulfills the condition GET
117 rules. Otherwise some other status code (which should be returned
118 to Apache).
119
120 since: 2.0.00
121
122 Refer to the Generating Correct HTTP Headers document for an indepth
123 discussion of this method.
124
125 "rationalize_mtime"
126 Return the latest rational time from a request/mtime pair.
127
128 $mtime_rat = $r->rationalize_mtime($mtime);
129
130 obj: $r ( "Apache2::RequestRec object" )
131 The current request
132
133 arg1: $mtime ( time in seconds )
134 The last modified time
135
136 ret: $mtime_rat ( time in seconds )
137 the latest rational time from a request/mtime pair. Mtime is
138 returned unless it's in the future, in which case we return the
139 current time.
140
141 since: 2.0.00
142
143 "send_cgi_header"
144 Parse the header
145
146 $r->send_cgi_header($buffer);
147
148 obj: $r ( "Apache2::RequestRec object" )
149 arg1: $buffer (string)
150 headers and optionally a response body
151
152 ret: no return value
153 since: 2.0.00
154
155 This method is really for back-compatibility with mod_perl 1.0. It's
156 very inefficient to send headers this way, because of the parsing
157 overhead.
158
159 If there is a response body following the headers it'll be handled too
160 (as if it was sent via "print()").
161
162 Notice that if only HTTP headers are included they won't be sent until
163 some body is sent (again the "send" part is retained from the mod_perl
164 1.0 method).
165
166 "set_content_length"
167 Set the content length for this request.
168
169 $r->set_content_length($length);
170
171 obj: $r ( "Apache2::RequestRec object" )
172 The current request
173
174 arg1: $length (integer)
175 The new content length
176
177 ret: no return value
178 since: 2.0.00
179
180 "set_etag"
181 Set the E-tag outgoing header
182
183 $r->set_etag();
184
185 obj: $r ( "Apache2::RequestRec object" )
186 ret: no return value
187 since: 2.0.00
188
189 "set_keepalive"
190 Set the keepalive status for this request
191
192 $ret = $r->set_keepalive();
193
194 obj: $r ( "Apache2::RequestRec object" )
195 The current request
196
197 ret: $ret ( boolean )
198 true if keepalive can be set, false otherwise
199
200 since: 2.0.00
201
202 It's called by "ap_http_header_filter()". For the complete complicated
203 logic implemented by this method see httpd-2.0/server/http_protocol.c.
204
205 "set_last_modified"
206 sets the "Last-Modified" response header field to the value of the
207 mtime field in the request structure -- rationalized to keep it from
208 being in the future.
209
210 $r->set_last_modified($mtime);
211
212 obj: $r ( "Apache2::RequestRec object" )
213 opt arg1: $mtime ( time in seconds )
214 if the $mtime argument is passed, $r->update_mtime will be first
215 run with that argument.
216
217 ret: no return value
218 since: 2.0.00
219
220 "update_mtime"
221 Set the "$r->mtime" field to the specified value if it's later than
222 what's already there.
223
224 $r->update_mtime($mtime);
225
226 obj: $r ( "Apache2::RequestRec object" )
227 The current request
228
229 arg1: $mtime ( time in seconds )
230 ret: no return value
231 since: 2.0.00
232
233 See also: $r->set_last_modified.
234
236 "Apache2::Response" also provides auto-generated Perl interface for a
237 few other methods which aren't tested at the moment and therefore their
238 API is a subject to change. These methods will be finalized later as a
239 need arises. If you want to rely on any of the following methods please
240 contact the the mod_perl development mailing list so we can help each
241 other take the steps necessary to shift the method to an officially
242 supported API.
243
244 "send_error_response"
245 Send an "error" response back to client. It is used for any response
246 that can be generated by the server from the request record. This
247 includes all 204 (no content), 3xx (redirect), 4xx (client error), and
248 5xx (server error) messages that have not been redirected to another
249 handler via the ErrorDocument feature.
250
251 $r->send_error_response($recursive_error);
252
253 obj: $r ( "Apache2::RequestRec object" )
254 The current request
255
256 arg1: $recursive_error ( boolean )
257 the error status in case we get an error in the process of trying
258 to deal with an "ErrorDocument" to handle some other error. In
259 that case, we print the default report for the first thing that
260 went wrong, and more briefly report on the problem with the
261 "ErrorDocument".
262
263 ret: no return value
264 since: 2.0.00
265
266 META: it's really an internal Apache method, I'm not quite sure how can
267 it be used externally.
268
269 "send_mmap"
270 META: Autogenerated - needs to be reviewed/completed
271
272 Send an MMAP'ed file to the client
273
274 $ret = $r->send_mmap($mm, $offset, $length);
275
276 obj: $r ( "Apache2::RequestRec object" )
277 The current request
278
279 arg1: $mm ("APR::Mmap")
280 The MMAP'ed file to send
281
282 arg2: $offset (number)
283 The offset into the MMAP to start sending
284
285 arg3: $length (integer)
286 The amount of data to send
287
288 ret: $ret (integer)
289 The number of bytes sent
290
291 since: 2.0.00
292
293 META: requires a working APR::Mmap, which is not supported at the
294 moment.
295
297 mod_perl 2.0 documentation.
298
300 mod_perl 2.0 and its core modules are copyrighted under The Apache
301 Software License, Version 2.0.
302
304 The mod_perl development team and numerous contributors.
305
306
307
308perl v5.30.0 2019-10-07 docs::api::Apache2::Response(3)