Apache::*::Table - Table classes for Apache::Request, Apache::Upload, and Apache::Cookie.
my $table = Apache::Request::Table->new($r); $table->{test} = 1; $table->{foo} = "bar1"; $table->add(foo => "bar2"); { my $do_data = ""; $table->do( sub { $do_data .= "@_,"; 1 } ); ok $do_data eq "test 1,foo bar1,foo bar2,"; }
This manpage documents the Apache::*::Table classes provided by the Apache::Request, Apache::Upload, and Apache::Cookie modules. Table classes are all derived from APR::Table, however since the underlying values they contain are not simple character arrays, the merge, compress, and overlap methods from APR::Table are not implemented.
merge
compress
overlap
These tables arise as parameter tables generated by the args, body, and param methods of Apache::Request. Their values are representable by orinary perl scalars, but unlike APR::Table, the '\0' character may be safely embedded in a value without truncating it.
args
body
param
my $table = Apache::Request::Table->new($r); my $value = "bar\0quux"; $table->{foo} = $value;
These tables arise from the Apache::Request::upload method (which is provided by Apache::Upload). Their values are Apache::Upload objects.
Apache::Request::upload
my $upload = Apache::Upload->new($r, name => "foo", file => __FILE__); my $table = Apache::Upload::Table->new($r); $table->add($upload); $upload = $table->{foo};
These tables arise from the cookies method of Apache::Cookie::Jar, and their values are Apache::Cookie objects (or Apache::Cookie derived objects- see the discussion of VALUE_CLASS in Apache::Cookie).
cookies
VALUE_CLASS
my $cookie = Apache::Cookie->new($r, name =>"foo", value => "bar"); my $table = Apache::Cookie::Table->new($r); $table->{foo} = $cookie; $cookie = $table->{foo};
Apache::Request, Apache::Cookie, Apache::Upload APR::Table(3)
Copyright 2003-2005 The Apache Software Foundation Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
To install Apache2::Upload, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Apache2::Upload
CPAN shell
perl -MCPAN -e shell install Apache2::Upload
For more information on module installation, please visit the detailed CPAN module installation guide.