From: Joshua Slive The Apache HTTP Server provides a mechanism for storing
information in named variables that are called environment
variables. This information can be used to control various
@@ -22,7 +10,7 @@
also used as a mechanism to communicate with external programs
such as CGI scripts. This document discusses different ways to
manipulate and use these variables. Although these variables are referred to as environment
variables, they are not the same as the environment
variables controlled by the underlying operating system.
@@ -34,260 +22,219 @@
server itself runs, you must use the standard environment
manipulation mechanisms provided by your operating system
shell. The most basic way to set an environment variable in Apache
- is using the unconditional For additional flexibility, the directives provided by
- mod_setenvif allow environment variables to be set on a
- per-request basis, conditional on characteristics of particular
- requests. For example, a variable could be set only when a
- specific browser (User-Agent) is making a request, or only when
- a specific Referer [sic] header is found. Even more flexibility
- is available through the mod_rewrite's Finally, mod_unique_id sets the environment variable
- In addition to all environment variables set within the
- Apache configuration and passed from the shell, CGI scripts and
- SSI pages are provided with a set of environment variables
- containing meta-information about the request as required by
- the CGI
- specification. One of the primary uses of environment variables is to
- communicate information to CGI scripts. As discussed above, the
- environment passed to CGI scripts includes standard
- meta-information about the request in addition to any variables
- set within the Apache configuration. For more details, see the
- CGI tutorial. Server-parsed (SSI) documents processed by mod_include's
- Access to the server can be controlled based on the value of
- environment variables using the Environment variables can be logged in the access log using
- the The The Interoperability problems have led to the introduction of
- mechanisms to modify the way Apache behaves when talking to
- particular clients. To make these mechanisms as flexible as
- possible, they are invoked by defining environment variables,
- typically with BrowserMatch,
- though SetEnv and PassEnv could also be used,
- for example. This forces the request to be treated as a HTTP/1.0 request
- even if it was in a later dialect. This causes any This forces an HTTP/1.0 response when set. It was originally
- implemented as a result of a problem with AOL's proxies. Some
- clients may not behave correctly when given an HTTP/1.1
- response, and this can be used to interoperate with them. This disables KeepAlive when set. This forces the server to be more careful when sending a redirect
- to the client. This is typically used when a client has a known
- problem handling redirects. This was originally implemented as a
- result of a problem with Microsoft's WebFolders software which has
- a problem handling redirects on directory resources via DAV
- methods. We recommend that the following lines be included in
- httpd.conf to deal with known client problems. The most basic way to set an environment variable in Apache
+ is using the unconditional For additional flexibility, the directives provided by
+ mod_setenvif allow environment variables to be set on a
+ per-request basis, conditional on characteristics of particular
+ requests. For example, a variable could be set only when a
+ specific browser (User-Agent) is making a request, or only when
+ a specific Referer [sic] header is found. Even more flexibility
+ is available through the mod_rewrite's Finally, mod_unique_id sets the environment variable
+ In addition to all environment variables set within the
+ Apache configuration and passed from the shell, CGI scripts and
+ SSI pages are provided with a set of environment variables
+ containing meta-information about the request as required by
+ the CGI
+ specification. One of the primary uses of environment variables is to
+ communicate information to CGI scripts. As discussed above, the
+ environment passed to CGI scripts includes standard
+ meta-information about the request in addition to any variables
+ set within the Apache configuration. For more details, see the
+ CGI tutorial. Server-parsed (SSI) documents processed by mod_include's
+ Access to the server can be controlled based on the value of
+ environment variables using the Environment variables can be logged in the access log using
+ the The The Interoperability problems have led to the introduction of
+ mechanisms to modify the way Apache behaves when talking to
+ particular clients. To make these mechanisms as flexible as
+ possible, they are invoked by defining environment variables,
+ typically with This forces the request to be treated as a HTTP/1.0 request
+ even if it was in a later dialect. This causes any This forces an HTTP/1.0 response when set. It was originally
+ implemented as a result of a problem with AOL's proxies. Some
+ clients may not behave correctly when given an HTTP/1.1
+ response, and this can be used to interoperate with them. This disables This forces the server to be more careful when sending a redirect
+ to the client. This is typically used when a client has a known
+ problem handling redirects. This was originally implemented as a
+ result of a problem with Microsoft's WebFolders software which has
+ a problem handling redirects on directory resources via DAV
+ methods. We recommend that the following lines be included in
+ httpd.conf to deal with known client problems. This example keeps requests for images from appearing in the
- access log. It can be easily modified to prevent logging of
- particular directories, or to prevent logging of requests
- coming from particular hosts. This example shows how to keep people not on your server
- from using images on your server as inline-images on their
- pages. This is not a recommended configuration, but it can work
- in limited circumstances. We assume that all your images are in
- a directory called /web/images. For more information about this technique, see the
- ApacheToday tutorial "
+BrowserMatch "JDK/1\.0" force-response-1.0 This example keeps requests for images from appearing in the
+ access log. It can be easily modified to prevent logging of
+ particular directories, or to prevent logging of requests
+ coming from particular hosts. This example shows how to keep people not on your server
+ from using images on your server as inline-images on their
+ pages. This is not a recommended configuration, but it can work
+ in limited circumstances. We assume that all your images are in
+ a directory called /web/images. For more information about this technique, see the
+ ApacheToday tutorial "
Keeping Your Images from Adorning Other Sites". The Apache HTTP Server provides a mechanism for storing
+ information in named variables that are called environment
+ variables. This information can be used to control various
+ operations such as logging or access control. The variables are
+ also used as a mechanism to communicate with external programs
+ such as CGI scripts. This document discusses different ways to
+ manipulate and use these variables. Although these variables are referred to as environment
+ variables, they are not the same as the environment
+ variables controlled by the underlying operating system.
+ Instead, these variables are stored and manipulated in an
+ internal Apache structure. They only become actual operating
+ system environment variables when they are provided to CGI
+ scripts and Server Side Include scripts. If you wish to
+ manipulate the operating system environment under which the
+ server itself runs, you must use the standard environment
+ manipulation mechanisms provided by your operating system
+ shell. The most basic way to set an environment variable in Apache
+ is using the unconditional For additional flexibility, the directives provided by
+ mod_setenvif allow environment variables to be set on a
+ per-request basis, conditional on characteristics of particular
+ requests. For example, a variable could be set only when a
+ specific browser (User-Agent) is making a request, or only when
+ a specific Referer [sic] header is found. Even more flexibility
+ is available through the mod_rewrite's Finally, mod_unique_id sets the environment variable
+ In addition to all environment variables set within the
+ Apache configuration and passed from the shell, CGI scripts and
+ SSI pages are provided with a set of environment variables
+ containing meta-information about the request as required by
+ the CGI
+ specification. One of the primary uses of environment variables is to
+ communicate information to CGI scripts. As discussed above, the
+ environment passed to CGI scripts includes standard
+ meta-information about the request in addition to any variables
+ set within the Apache configuration. For more details, see the
+ CGI tutorial. Server-parsed (SSI) documents processed by mod_include's
+ Access to the server can be controlled based on the value of
+ environment variables using the Environment variables can be logged in the access log using
+ the The The Interoperability problems have led to the introduction of
+ mechanisms to modify the way Apache behaves when talking to
+ particular clients. To make these mechanisms as flexible as
+ possible, they are invoked by defining environment variables,
+ typically with This forces the request to be treated as a HTTP/1.0 request
+ even if it was in a later dialect. This causes any This forces an HTTP/1.0 response when set. It was originally
+ implemented as a result of a problem with AOL's proxies. Some
+ clients may not behave correctly when given an HTTP/1.1
+ response, and this can be used to interoperate with them. This disables This forces the server to be more careful when sending a redirect
+ to the client. This is typically used when a client has a known
+ problem handling redirects. This was originally implemented as a
+ result of a problem with Microsoft's WebFolders software which has
+ a problem handling redirects on directory resources via DAV
+ methods. We recommend that the following lines be included in
+ httpd.conf to deal with known client problems. This example keeps requests for images from appearing in the
+ access log. It can be easily modified to prevent logging of
+ particular directories, or to prevent logging of requests
+ coming from particular hosts. This example shows how to keep people not on your server
+ from using images on your server as inline-images on their
+ pages. This is not a recommended configuration, but it can work
+ in limited circumstances. We assume that all your images are in
+ a directory called /web/images. For more information about this technique, see the
+ ApacheToday tutorial "
+ Keeping Your Images from Adorning Other Sites". This document describes the use of filters in Apache. A filter is a process that is applied to data that
is sent or received by the server. Data sent by clients to the
server is processed by input filters while data sent
@@ -53,25 +19,18 @@
as chunking and byte-range request handling. In addition, modules
can provide filters that are selectable using run-time
configuration directives. The set of filters that apply to data
- can be manipulated with the Environment Variables in Apache
-
+Apache HTTP Server Version 2.0
Environment Variables in Apache
-
-
-
- Setting Environment
- Variables
-
-
-
-
-
-
- Related Modules
-
-
-
- mod_env
- mod_rewrite
- mod_setenvif
- mod_unique_id
- Related Directives
-
-
- BrowserMatch
- BrowserMatchNoCase
- PassEnv
- RewriteRule
- SetEnv
- SetEnvIf
- SetEnvIfNoCase
- UnsetEnv
- Basic Environment Manipulation
-
- SetEnv
directive.
- Variables may also be passed from the environment of the shell
- which started the server using the PassEnv
- directive.Conditional Per-Request Settings
-
- RewriteRule
- which uses the [E=...]
option to set environment
- variables.Unique Identifiers
-
- UNIQUE_ID
for each request to a value which is
- guaranteed to be unique across "all" requests under very
- specific conditions.Standard CGI Variables
-
- Some Caveats
-
-
-
- suexec.c
.
-
- Using Environment
- Variables
-
-
-
-
-
-
- Related Modules
-
-
-
- mod_access
- mod_cgi
- mod_headers
- mod_include
- mod_log_config
- mod_rewrite
- Related Directives
-
-
- Allow
- CustomLog
- Deny
- Header
- LogFormat
- RewriteCond
- RewriteRule
- CGI Scripts
-
- SSI Pages
-
- INCLUDES
filter can print environment variables
- using the echo
element, and can use environment
- variables in flow control elements to makes parts of a page
- conditional on characteristics of a request. Apache also
- provides SSI pages with the standard CGI environment variables
- as discussed above. For more details, see the SSI tutorial.Access Control
-
- allow from env=
- and deny from env=
directives. In combination with
- SetEnvIf
, this allows for flexible control of
- access to the server based on characteristics of the client.
- For example, you can use these directives to deny access to a
- particular browser (User-Agent).Conditional Logging
-
- LogFormat
option %e
. In addition,
- the decision on whether or not to log requests can be made
- based on the status of environment variables using the
- conditional form of the CustomLog
directive. In
- combination with SetEnvIf
this allows for flexible
- control of which requests are logged. For example, you can
- choose not to log requests for filenames ending in
- gif
, or you can choose to only log requests from
- clients which are outside your subnet.Conditional Response Headers
-
- Header
directive can use the presence or
- absence of an environment variable to determine whether or not
- a certain HTTP header will be placed in the response to the
- client. This allows, for example, a certain response header to
- be sent only if a corresponding header is received in the
- request from the client.URL Rewriting
-
- %{ENV:...}
form of TestString in
- the RewriteCond
allows mod_rewrite's rewrite
- engine to make decisions conditional on environment variables.
- Note that the variables accessible in mod_rewrite without the
- ENV:
prefix are not actually environment
- variables. Rather, they are variables special to mod_rewrite
- which cannot be accessed from other modules.
-
- Special Purpose Environment
- Variables
-
- downgrade-1.0
-
- force-no-vary
-
- Vary
fields to be removed from
- the response header before it is sent back to the client. Some
- clients don't interpret this field correctly (see the known client
- problems page); setting this variable can work around this
- problem. Setting this variable also implies
- force-response-1.0.force-response-1.0
-
- nokeepalive
-
- redirect-carefully
-
-
- Examples
-
- Changing protocol behavior with misbehaving clients
-
-
+
Setting Environment Variables
+
+
+
+ Related Modules mod_env
, mod_rewrite
, mod_setenvif
, mod_unique_id
Related Directives BrowserMatch
BrowserMatchNoCase
PassEnv
RewriteRule
SetEnv
SetEnvIf
SetEnvIfNoCase
UnsetEnv
Basic Environment Manipulation
+
+
+ SetEnv
directive. Variables may also be passed from
+ the environment of the shell which started the server using the
+ PassEnv
directive.Conditional Per-Request Settings
+
+
+ RewriteRule
which uses the
+ [E=...]
option to set environment variables.Unique Identifiers
+
+
+ UNIQUE_ID
for each request to a value which is
+ guaranteed to be unique across "all" requests under very
+ specific conditions.Standard CGI Variables
+
+
+ Some Caveats
+
+
+
+
+
+ suexec.c
.Using Environment Variables
+
+
+
+
+ Related Modules mod_access
, mod_cgi
, mod_headers
, mod_include
, mod_log_config
, mod_rewrite
Related Directives Allow
CustomLog
Deny
Header
LogFormat
RewriteCond
RewriteRule
CGI Scripts
+
+
+ SSI Pages
+
+
+ INCLUDES
filter can print environment variables
+ using the echo
element, and can use environment
+ variables in flow control elements to makes parts of a page
+ conditional on characteristics of a request. Apache also
+ provides SSI pages with the standard CGI environment variables
+ as discussed above. For more details, see the SSI tutorial.Access Control
+
+
+ allow from env=
+ and deny from env=
directives. In combination with
+ SetEnvIf
, this
+ allows for flexible control of access to the server based on
+ characteristics of the client. For example, you can use these
+ directives to deny access to a particular browser (User-Agent).
+ Conditional Logging
+
+
+ LogFormat
+ option %e
. In addition, the decision on whether
+ or not to log requests can be made based on the status of
+ environment variables using the conditional form of the
+ CustomLog
+ directive. In combination with SetEnvIf
this allows for flexible control of which
+ requests are logged. For example, you can choose not to log
+ requests for filenames ending in gif
, or you can
+ choose to only log requests from clients which are outside your
+ subnet.Conditional Response Headers
+
+
+ Header
+ directive can use the presence or
+ absence of an environment variable to determine whether or not
+ a certain HTTP header will be placed in the response to the
+ client. This allows, for example, a certain response header to
+ be sent only if a corresponding header is received in the
+ request from the client.URL Rewriting
+
+
+ %{ENV:...}
form of TestString in
+ the RewriteCond
+ allows mod_rewrite's rewrite
+ engine to make decisions conditional on environment variables.
+ Note that the variables accessible in mod_rewrite without the
+ ENV:
prefix are not actually environment
+ variables. Rather, they are variables special to mod_rewrite
+ which cannot be accessed from other modules.Special Purpose Environment Variables
+
+
+ BrowserMatch
,
+ though SetEnv
and
+ PassEnv
could also be used,
+ for example.downgrade-1.0
+
+
+ force-no-vary
+
+
+ Vary
fields to be removed from
+ the response header before it is sent back to the client. Some
+ clients don't interpret this field correctly (see the known client
+ problems page); setting this variable can work around this
+ problem. Setting this variable also implies
+ force-response-1.0.force-response-1.0
+
+
+ nokeepalive
+
+
+ KeepAlive
when set.redirect-carefully
+
+
+ Examples
+
+
+ Changing protocol behavior with misbehaving clients
+
+
+
+
+
+
#
# The following directives modify normal HTTP response behavior.
# The first directive disables keepalive for Netscape 2.x and browsers that
@@ -306,45 +253,43 @@ BrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0
#
BrowserMatch "RealPlayer 4\.0" force-response-1.0
BrowserMatch "Java/1\.0" force-response-1.0
-BrowserMatch "JDK/1\.0" force-response-1.0
-
-
- Do not log requests for images in the access log
-
-
- SetEnvIf Request_URI \.gif image-request
- SetEnvIf Request_URI \.jpg image-request
- SetEnvIf Request_URI \.png image-request
- CustomLog logs/access_log common env=!image-request
-
-
- Prevent "Image Theft"
-
-
- SetEnvIf Referer "^http://www.example.com/" local_referal
- # Allow browsers that do not send Referer info
- SetEnvIf Referer "^$" local_referal
- <Directory /web/images>
- Order Deny,Allow
- Deny from all
- Allow from env=local_referal
- </Directory>
-
-
- Do not log requests for images in the access log
+
+
+
+
+
+
+SetEnvIf Request_URI \.gif image-request
+SetEnvIf Request_URI \.jpg image-request
+SetEnvIf Request_URI \.png image-request
+CustomLog logs/access_log common env=!image-request
Prevent "Image Theft"
+
+
+
+
+
+SetEnvIf Referer "^http://www.example.com/" local_referal
+# Allow browsers that do not send Referer info
+SetEnvIf Referer "^$" local_referal
+<Directory /web/images>
+ Order Deny,Allow
+ Deny from all
+ Allow from env=local_referal
+</Directory>
Apache HTTP Server Version 2.0
\ No newline at end of file
diff --git a/docs/manual/env.xml b/docs/manual/env.xml
new file mode 100644
index 0000000000..263e3527dc
--- /dev/null
+++ b/docs/manual/env.xml
@@ -0,0 +1,353 @@
+
+
+
+
+
[E=...]
option to set environment variables.UNIQUE_ID
for each request to a value which is
+ guaranteed to be unique across "all" requests under very
+ specific conditions.
+
+ suexec.c
.INCLUDES
filter can print environment variables
+ using the echo
element, and can use environment
+ variables in flow control elements to makes parts of a page
+ conditional on characteristics of a request. Apache also
+ provides SSI pages with the standard CGI environment variables
+ as discussed above. For more details, see the SSI tutorial.allow from env=
+ and deny from env=
directives. In combination with
+ %e
. In addition, the decision on whether
+ or not to log requests can be made based on the status of
+ environment variables using the conditional form of the
+ gif
, or you can
+ choose to only log requests from clients which are outside your
+ subnet.%{ENV:...}
form of TestString in
+ the ENV:
prefix are not actually environment
+ variables. Rather, they are variables special to mod_rewrite
+ which cannot be accessed from other modules.Vary
fields to be removed from
+ the response header before it is sent back to the client. Some
+ clients don't interpret this field correctly (see the known client
+ problems page); setting this variable can work around this
+ problem. Setting this variable also implies
+ force-response-1.0.
+#
+# The following directives modify normal HTTP response behavior.
+# The first directive disables keepalive for Netscape 2.x and browsers that
+# spoof it. There are known problems with these browser implementations.
+# The second directive is for Microsoft Internet Explorer 4.0b2
+# which has a broken HTTP/1.1 implementation and does not properly
+# support keepalive when it is used on 301 or 302 (redirect) responses.
+#
+BrowserMatch "Mozilla/2" nokeepalive
+BrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0
+
+#
+# The following directive disables HTTP/1.1 responses to browsers which
+# are in violation of the HTTP/1.0 spec by not being able to grok a
+# basic 1.1 response.
+#
+BrowserMatch "RealPlayer 4\.0" force-response-1.0
+BrowserMatch "Java/1\.0" force-response-1.0
+BrowserMatch "JDK/1\.0" force-response-1.0
+SetEnvIf Request_URI \.gif image-request
+SetEnvIf Request_URI \.jpg image-request
+SetEnvIf Request_URI \.png image-request
+CustomLog logs/access_log common env=!image-request
+SetEnvIf Referer "^http://www.example.com/" local_referal
+# Allow browsers that do not send Referer info
+SetEnvIf Referer "^$" local_referal
+<Directory /web/images>
+ Order Deny,Allow
+ Deny from all
+ Allow from env=local_referal
+</Directory>
Filters
-
-
-
-
+
-
- Related Modules
-
-
-
- mod_deflate
- mod_ext_filter
- mod_include
- Related Directives
-
-
- AddInputFilter
- AddOutputFilter
- ExtFilterDefine
- ExtFilterOptions
- SetInputFilter
- SetOutputFilter
- Apache HTTP Server Version 2.0
Filters
+ Filters
+
+
+
Related Modules mod_deflate
, mod_ext_filter
, mod_include
Related Directives AddInputFilter
AddOutputFilter
ExtFilterDefine
ExtFilterOptions
SetInputFilter
SetOutputFilter
SetInputFilter
,
- SetOutputFilter
, AddInputFilter
, and
- AddOutputFilter
directives.SetInputFilter
, SetOutputFilter
, AddInputFilter
, and AddOutputFilter
directives.
The following user-selectable filters are currently provided with the Apache HTTP Server distribution.
-mod_include
mod_include
In addition, the module mod_ext_filter allows +
In addition, the module mod_ext_filter
allows
for external programs to be defined as filters.
This document describes the use of filters in Apache.
+A filter is a process that is applied to data that + is sent or received by the server. Data sent by clients to the + server is processed by input filters while data sent + by the server to the client is processed by output + filters. Multiple filters can be applied to the data, and + the order of the filters can be explicitly specified.
+ +Filters are used internally by Apache to perform functions such
+ as chunking and byte-range request handling. In addition, modules
+ can provide filters that are selectable using run-time
+ configuration directives. The set of filters that apply to data
+ can be manipulated with the
The following user-selectable filters are currently provided + with the Apache HTTP Server distribution.
+ +In addition, the module
Related Modules - - mod_actions - mod_asis - mod_cgi - mod_imap - mod_info - mod_mime - mod_negotiation - mod_status - |
-
- Related Directives - - Action - AddHandler - RemoveHandler - SetHandler - |
-
Apache HTTP Server Version 2.0
Apache's Handler Use
+This document describes the use of Apache's Handlers.
+What is a Handler
+ ++
Related Modules mod_actions
,mod_asis
,mod_cgi
,mod_imap
,mod_info
,mod_mime
,mod_negotiation
,mod_status
Related Directives Action
AddHandler
RemoveHandler
SetHandler
A "handler" is an internal Apache representation of the action to be performed when a file is called. Generally, files @@ -66,13 +20,11 @@ can be specified without relation to file type. This is advantageous both because it is a more elegant solution, and because it also allows for both a type and a - handler to be associated with a file. (See also Files with Multiple + handler to be associated with a file. (See also Files with Multiple Extensions.)
Handlers can either be built into the server or included in - a module, or they can be added with the Action directive. The + a module, or they can be added with the
@@ -82,61 +34,63 @@ default to handle static content. (core)Action
directive. The built-in handlers in the standard distribution are as follows:send-as-is: Send file with HTTP headers - as is. (mod_asis) + as is. (mod_asis
)cgi-script: Treat the file as a CGI - script. (mod_cgi) + script. (mod_cgi
)imap-file: Parse as an imagemap rule - file. (mod_imap) + file. (mod_imap
)server-info: Get the server's - configuration information. (mod_info) + configuration information. (mod_info
)server-status: Get the server's status - report. (mod_status) + report. (mod_status
)type-map: Parse as a type map file for - content negotiation. (mod_negotiation) + content negotiation. (mod_negotiation
) -
- -Examples
- -Modifying static content using a CGI script
- -The following directives will cause requests for files with - the
-html
extension to trigger the launch of the -footer.pl
CGI script.- Action add-footer /cgi-bin/footer.pl - AddHandler add-footer .html -- -Then the CGI script is responsible for sending the - originally requested document (pointed to by the -
- -PATH_TRANSLATED
environment variable) and making - whatever modifications or additions are desired.Files with HTTP headers
- -The following directives will enable the -
-send-as-is
handler, which is used for files which - contain their own HTTP headers. All files in the -/web/htdocs/asis/
directory will be processed by - thesend-as-is
handler, regardless of their - filename extensions.- <Directory /web/htdocs/asis> - SetHandler send-as-is - </Directory> --
- -Programmer's - Note
+Examples
+ + +Modifying static content using a CGI script
+ + +The following directives will cause requests for files with + the
+ +html
extension to trigger the launch of the +footer.pl
CGI script.+ +
+ Action add-footer /cgi-bin/footer.pl
+ AddHandler add-footer .html +Then the CGI script is responsible for sending the + originally requested document (pointed to by the +
+ + +PATH_TRANSLATED
environment variable) and making + whatever modifications or additions are desired.Files with HTTP headers
+ + +The following directives will enable the +
+ +send-as-is
handler, which is used for files which + contain their own HTTP headers. All files in the +/web/htdocs/asis/
directory will be processed by + thesend-as-is
handler, regardless of their + filename extensions.+ + +
+ <Directory /web/htdocs/asis>
+ SetHandler send-as-is
+ </Directory> +Programmer's Note
+In order to implement the handler features, an addition has been made to the Apache API that @@ -154,7 +108,4 @@ type. While it is not necessary, the naming convention for handlers is to use a dash-separated word, with no slashes, so as to not invade the media type name-space.
- - - - +
This document describes the use of Apache's Handlers.
+A "handler" is an internal Apache representation of the + action to be performed when a file is called. Generally, files + have implicit handlers, based on the file type. Normally, all + files are simply served by the server, but certain file types + are "handled" separately.
+ +Apache 1.1 adds the ability to use handlers explicitly. + Based on either filename extensions or on location, handlers + can be specified without relation to file type. This is + advantageous both because it is a more elegant solution, and + because it also allows for both a type and a + handler to be associated with a file. (See also Files with Multiple + Extensions.)
+ +Handlers can either be built into the server or included in
+ a module, or they can be added with the
default_handler()
, which is the handler used by
+ default to handle static content. (core)The following directives will cause requests for files with
+ the html
extension to trigger the launch of the
+ footer.pl
CGI script.
+ Action add-footer /cgi-bin/footer.pl
+ AddHandler add-footer .html
+
Then the CGI script is responsible for sending the
+ originally requested document (pointed to by the
+ PATH_TRANSLATED
environment variable) and making
+ whatever modifications or additions are desired.
The following directives will enable the
+ send-as-is
handler, which is used for files which
+ contain their own HTTP headers. All files in the
+ /web/htdocs/asis/
directory will be processed by
+ the send-as-is
handler, regardless of their
+ filename extensions.
+ <Directory /web/htdocs/asis>
+ SetHandler send-as-is
+ </Directory>
+
In order to implement the handler features, an addition has
+ been made to the Apache API that
+ you may wish to make use of. Specifically, a new record has
+ been added to the request_rec
structure:
+ char *handler ++ +
If you wish to have your module engage a handler, you need
+ only to set r->handler
to the name of the
+ handler at any time prior to the invoke_handler
+ stage of the request. Handlers are implemented as they were
+ before, albeit using the handler name instead of a content
+ type. While it is not necessary, the naming convention for
+ handlers is to use a dash-separated word, with no slashes, so
+ as to not invade the media type name-space.