diff options
author | Jason McIntyre <jmc@cvs.openbsd.org> | 2005-07-27 20:03:18 +0000 |
---|---|---|
committer | Jason McIntyre <jmc@cvs.openbsd.org> | 2005-07-27 20:03:18 +0000 |
commit | 43f4360318806f8329871748ee96168bdf9edfda (patch) | |
tree | 8149b18d28c10f58adcde4b810362ed778beb9b7 /usr.sbin/httpd/htdocs/manual/howto | |
parent | 3184c655b8f6643d96bbf0c8e31388c1c587fdfe (diff) |
from tamas tevesz:
more altlangs removal, missed from previous sweep;
Diffstat (limited to 'usr.sbin/httpd/htdocs/manual/howto')
-rw-r--r-- | usr.sbin/httpd/htdocs/manual/howto/cgi.html.en | 563 | ||||
-rw-r--r-- | usr.sbin/httpd/htdocs/manual/howto/cgi.html.ja.jis | 562 | ||||
-rw-r--r-- | usr.sbin/httpd/htdocs/manual/howto/ssi.html.en | 554 | ||||
-rw-r--r-- | usr.sbin/httpd/htdocs/manual/howto/ssi.html.ja.jis | 554 |
4 files changed, 0 insertions, 2233 deletions
diff --git a/usr.sbin/httpd/htdocs/manual/howto/cgi.html.en b/usr.sbin/httpd/htdocs/manual/howto/cgi.html.en deleted file mode 100644 index 056f5b9b08b..00000000000 --- a/usr.sbin/httpd/htdocs/manual/howto/cgi.html.en +++ /dev/null @@ -1,563 +0,0 @@ -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" - "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> - -<html xmlns="http://www.w3.org/1999/xhtml"> - <head> - <meta name="generator" content="HTML Tidy, see www.w3.org" /> - - <title>Apache Tutorial: Dynamic Content with CGI</title> - </head> - <!-- Background white, links blue (unvisited), navy (visited), red (active) --> - - <body bgcolor="#FFFFFF" text="#000000" link="#0000FF" - vlink="#000080" alink="#FF0000"> - <div align="CENTER"> - <img src="../images/sub.gif" alt="[APACHE DOCUMENTATION]" /> - - <h3>Apache HTTP Server Version 1.3</h3> - </div> - - - - <h1 align="CENTER">Dynamic Content with CGI</h1> - <a id="__index__" name="__index__"></a> <!-- INDEX BEGIN --> - - - <ul> - <li><a href="#dynamiccontentwithcgi">Dynamic Content with - CGI</a></li> - - <li> - <a href="#configuringapachetopermitcgi">Configuring Apache - to permit CGI</a> - - <ul> - <li><a href="#scriptalias">ScriptAlias</a></li> - - <li> - <a href="#cgioutsideofscriptaliasdirectories">CGI - outside of ScriptAlias directories</a> - - <ul> - <li><a - href="#explicitlyusingoptionstopermitcgiexecution">Explicitly - using Options to permit CGI execution</a></li> - - <li><a href="#htaccessfiles">.htaccess files</a></li> - </ul> - </li> - </ul> - </li> - - <li> - <a href="#writingacgiprogram">Writing a CGI program</a> - - <ul> - <li><a href="#yourfirstcgiprogram">Your first CGI - program</a></li> - </ul> - </li> - - <li> - <a href="#butitsstillnotworking">But it's still not - working!</a> - - <ul> - <li><a href="#filepermissions">File permissions</a></li> - - <li><a href="#pathinformation">Path information</a></li> - - <li><a href="#syntaxerrors">Syntax errors</a></li> - - <li><a href="#errorlogs">Error logs</a></li> - </ul> - </li> - - <li> - <a href="#whatsgoingonbehindthescenes">What's going on - behind the scenes?</a> - - <ul> - <li><a href="#environmentvariables">Environment - variables</a></li> - - <li><a href="#stdinandstdout">STDIN and STDOUT</a></li> - </ul> - </li> - - <li><a href="#cgimoduleslibraries">CGI - modules/libraries</a></li> - - <li><a href="#formoreinformation">For more - information</a></li> - </ul> - <!-- INDEX END --> - <hr /> - - <h2><a id="dynamiccontentwithcgi" - name="dynamiccontentwithcgi">Dynamic Content with CGI</a></h2> - - <table border="1"> - <tr> - <td valign="top"><strong>Related Modules</strong><br /> - <br /> - <a href="../mod/mod_alias.html">mod_alias</a><br /> - <a href="../mod/mod_cgi.html">mod_cgi</a><br /> - </td> - - <td valign="top"><strong>Related Directives</strong><br /> - <br /> - <a - href="../mod/mod_mime.html#addhandler">AddHandler</a><br /> - <a href="../mod/core.html#options">Options</a><br /> - <a - href="../mod/mod_alias.html#scriptalias">ScriptAlias</a><br /> - </td> - </tr> - </table> - - <p>The CGI (Common Gateway Interface) defines a way for a web - server to interact with external content-generating programs, - which are often referred to as CGI programs or CGI scripts. It - is the simplest, and most common, way to put dynamic content on - your web site. This document will be an introduction to setting - up CGI on your Apache web server, and getting started writing - CGI programs.</p> - <hr /> - - <h2><a id="configuringapachetopermitcgi" - name="configuringapachetopermitcgi">Configuring Apache to - permit CGI</a></h2> - - <p>In order to get your CGI programs to work properly, you'll - need to have Apache configured to permit CGI execution. There - are several ways to do this.</p> - - <h3><a id="scriptalias" name="scriptalias">ScriptAlias</a></h3> - - <p>The <code>ScriptAlias</code> directive tells Apache that a - particular directory is set aside for CGI programs. Apache will - assume that every file in this directory is a CGI program, and - will attempt to execute it, when that particular resource is - requested by a client.</p> - - <p>The <code>ScriptAlias</code> directive looks like:</p> -<pre> - ScriptAlias /cgi-bin/ /usr/local/apache/cgi-bin/ -</pre> - - <p>The example shown is from your default - <code>httpd.conf</code> configuration file, if you installed - Apache in the default location. The <code>ScriptAlias</code> - directive is much like the <code>Alias</code> directive, which - defines a URL prefix that is to mapped to a particular - directory. <code>Alias</code> and <code>ScriptAlias</code> are - usually used for directories that are outside of the - <code>DocumentRoot</code> directory. The difference between - <code>Alias</code> and <code>ScriptAlias</code> is that - <code>ScriptAlias</code> has the added meaning that everything - under that URL prefix will be considered a CGI program. So, the - example above tells Apache that any request for a resource - beginning with <code>/cgi-bin/</code> should be served from the - directory <code>/usr/local/apache/cgi-bin/</code>, and should - be treated as a CGI program.</p> - - <p>For example, if the URL - <code>http://www.example.com/cgi-bin/test.pl</code> is - requested, Apache will attempt to execute the file - <code>/usr/local/apache/cgi-bin/test.pl</code> and return the - output. Of course, the file will have to exist, and be - executable, and return output in a particular way, or Apache - will return an error message.</p> - - <h3><a id="cgioutsideofscriptaliasdirectories" - name="cgioutsideofscriptaliasdirectories">CGI outside of - ScriptAlias directories</a></h3> - - <p>CGI programs are often restricted to - <code>ScriptAlias</code>'ed directories for security reasons. - In this way, administrators can tightly control who is allowed - to use CGI programs. However, if the proper security - precautions are taken, there is no reason why CGI programs - cannot be run from arbitrary directories. For example, you may - wish to let users have web content in their home directories - with the <code>UserDir</code> directive. If they want to have - their own CGI programs, but don't have access to the main - <code>cgi-bin</code> directory, they will need to be able to - run CGI programs elsewhere.</p> - - <h3><a id="explicitlyusingoptionstopermitcgiexecution" - name="explicitlyusingoptionstopermitcgiexecution">Explicitly - using Options to permit CGI execution</a></h3> - - <p>You could explicitly use the <code>Options</code> directive, - inside your main server configuration file, to specify that CGI - execution was permitted in a particular directory:</p> -<pre> - <Directory /usr/local/apache/htdocs/somedir> - Options +ExecCGI - </Directory> -</pre> - - <p>The above directive tells Apache to permit the execution of - CGI files. You will also need to tell the server what files are - CGI files. The following <code>AddHandler</code> directive - tells the server to treat all files with the <code>cgi</code> - or <code>pl</code> extension as CGI programs:</p> -<pre> - AddHandler cgi-script cgi pl -</pre> - - <h3><a id="htaccessfiles" name="htaccessfiles">.htaccess - files</a></h3> - - <p>A <code>.htaccess</code> file is a way to set configuration - directives on a per-directory basis. When Apache serves a - resource, it looks in the directory from which it is serving a - file for a file called <code>.htaccess</code>, and, if it finds - it, it will apply directives found therein. - <code>.htaccess</code> files can be permitted with the - <code>AllowOverride</code> directive, which specifies what - types of directives can appear in these files, or if they are - not allowed at all. To permit the directive we will need for - this purpose, the following configuration will be needed in - your main server configuration:</p> -<pre> - AllowOverride Options -</pre> - - <p>In the <code>.htaccess</code> file, you'll need the - following directive:</p> -<pre> - Options +ExecCGI -</pre> - - <p>which tells Apache that execution of CGI programs is - permitted in this directory.</p> - <hr /> - - <h2><a id="writingacgiprogram" - name="writingacgiprogram">Writing a CGI program</a></h2> - - <p>There are two main differences between ``regular'' - programming, and CGI programming.</p> - - <p>First, all output from your CGI program must be preceded by - a MIME-type header. This is HTTP header that tells the client - what sort of content it is receiving. Most of the time, this - will look like:</p> -<pre> - Content-type: text/html -</pre> - - <p>Secondly, your output needs to be in HTML, or some other - format that a browser will be able to display. Most of the - time, this will be HTML, but occasionally you might write a CGI - program that outputs a gif image, or other non-HTML - content.</p> - - <p>Apart from those two things, writing a CGI program will look - a lot like any other program that you might write.</p> - - <h3><a id="yourfirstcgiprogram" name="yourfirstcgiprogram">Your - first CGI program</a></h3> - - <p>The following is an example CGI program that prints one line - to your browser. Type in the following, save it to a file - called <code>first.pl</code>, and put it in your - <code>cgi-bin</code> directory.</p> -<pre> - #!/usr/bin/perl - print "Content-type: text/html\r\n\r\n"; - print "Hello, World."; -</pre> - - <p>Even if you are not familiar with Perl, you should be able - to see what is happening here. The first line tells Apache (or - whatever shell you happen to be running under) that this - program can be executed by feeding the file to the interpreter - found at the location <code>/usr/bin/perl</code>. The second - line prints the content-type declaration we talked about, - followed by two carriage-return newline pairs. This puts a - blank line after the header, to indicate the end of the HTTP - headers, and the beginning of the body. The third line prints - the string ``Hello, World.'' And that's the end of it.</p> - - <p>If you open your favorite browser and tell it to get the - address</p> -<pre> - http://www.example.com/cgi-bin/first.pl -</pre> - - <p>or wherever you put your file, you will see the one line - <code>Hello, World.</code> appear in your browser window. It's - not very exciting, but once you get that working, you'll have a - good chance of getting just about anything working.</p> - <hr /> - - <h2><a id="butitsstillnotworking" - name="butitsstillnotworking">But it's still not - working!</a></h2> - - <p>There are four basic things that you may see in your browser - when you try to access your CGI program from the web:</p> - - <dl> - <dt>The output of your CGI program</dt> - - <dd>Great! That means everything worked fine.<br /> - <br /> - </dd> - - <dt>The source code of your CGI program or a "POST Method Not - Allowed" message</dt> - - <dd>That means that you have not properly configured Apache - to process your CGI program. Reread the section on <a - href="#configuringapachetopermitcgi">configuring Apache</a> - and try to find what you missed.<br /> - <br /> - </dd> - - <dt>A message starting with "Forbidden"</dt> - - <dd>That means that there is a permissions problem. Check the - <a href="#errorlogs">Apache error log</a> and the section - below on <a href="#filepermissions">file - permissions</a>.<br /> - <br /> - </dd> - - <dt>A message saying "Internal Server Error"</dt> - - <dd>If you check the <a href="#errorlogs">Apache error - log</a>, you will probably find that it says "Premature end - of script headers", possibly along with an error message - generated by your CGI program. In this case, you will want to - check each of the below sections to see what might be - preventing your CGI program from emitting the proper HTTP - headers.</dd> - </dl> - - <h3><a id="filepermissions" name="filepermissions">File - permissions</a></h3> - - <p>Remember that the server does not run as you. That is, when - the server starts up, it is running with the permissions of an - unprivileged user - usually ``nobody'', or ``www'' - and so it - will need extra permissions to execute files that are owned by - you. Usually, the way to give a file sufficient permissions to - be executed by ``nobody'' is to give everyone execute - permission on the file:</p> -<pre> - chmod a+x first.pl -</pre> - - <p>Also, if your program reads from, or writes to, any other - files, those files will need to have the correct permissions to - permit this.</p> - - <p>The exception to this is when the server is configured to - use <a href="../suexec.html">suexec</a>. This program allows - CGI programs to be run under different user permissions, - depending on which virtual host or user home directory they are - located in. Suexec has very strict permission checking, and any - failure in that checking will result in your CGI programs - failing with an "Internal Server Error". In this case, you will - need to check the suexec log file to see what specific security - check is failing.</p> - - <h3><a id="pathinformation" name="pathinformation">Path - information</a></h3> - - <p>When you run a program from your command line, you have - certain information that is passed to the shell without you - thinking about it. For example, you have a path, which tells - the shell where it can look for files that you reference.</p> - - <p>When a program runs through the web server as a CGI program, - it does not have that path. Any programs that you invoke in - your CGI program (like 'sendmail', for example) will need to be - specified by a full path, so that the shell can find them when - it attempts to execute your CGI program.</p> - - <p>A common manifestation of this is the path to the script - interpreter (often <code>perl</code>) indicated in the first - line of your CGI program, which will look something like:</p> -<pre> - #!/usr/bin/perl -</pre> - - <p>Make sure that this is in fact the path to the - interpreter.</p> - - <h3><a id="syntaxerrors" name="syntaxerrors">Syntax - errors</a></h3> - - <p>Most of the time when a CGI program fails, it's because of a - problem with the program itself. This is particularly true once - you get the hang of this CGI stuff, and no longer make the - above two mistakes. Always attempt to run your program from the - command line before you test if via a browser. This will - eliminate most of your problems.</p> - - <h3><a id="errorlogs" name="errorlogs">Error logs</a></h3> - - <p>The error logs are your friend. Anything that goes wrong - generates message in the error log. You should always look - there first. If the place where you are hosting your web site - does not permit you access to the error log, you should - probably host your site somewhere else. Learn to read the error - logs, and you'll find that almost all of your problems are - quickly identified, and quickly solved.</p> - <hr /> - - <h2><a id="whatsgoingonbehindthescenes" - name="whatsgoingonbehindthescenes">What's going on behind the - scenes?</a></h2> - - <p>As you become more advanced in CGI programming, it will - become useful to understand more about what's happening behind - the scenes. Specifically, how the browser and server - communicate with one another. Because although it's all very - well to write a program that prints ``Hello, World.'', it's not - particularly useful.</p> - - <h3><a id="environmentvariables" - name="environmentvariables">Environment variables</a></h3> - - <p>Environment variables are values that float around you as - you use your computer. They are useful things like your path - (where the computer searches for a the actual file implementing - a command when you type it), your username, your terminal type, - and so on. For a full list of your normal, every day - environment variables, type <code>env</code> at a command - prompt.</p> - - <p>During the CGI transaction, the server and the browser also - set environment variables, so that they can communicate with - one another. These are things like the browser type (Netscape, - IE, Lynx), the server type (Apache, IIS, WebSite), the name of - the CGI program that is being run, and so on.</p> - - <p>These variables are available to the CGI programmer, and are - half of the story of the client-server communication. The - complete list of required variables is at <a - href="http://hoohoo.ncsa.uiuc.edu/cgi/env.html">http://hoohoo.ncsa.uiuc.edu/cgi/env.html</a></p> - - <p>This simple Perl CGI program will display all of the - environment variables that are being passed around. Two similar - programs are included in the <code>cgi-bin</code> directory of - the Apache distribution. Note that some variables are required, - while others are optional, so you may see some variables listed - that were not in the official list. In addition, Apache - provides many different ways for you to <a - href="../env.html">add your own environment variables</a> to - the basic ones provided by default.</p> -<pre> - #!/usr/bin/perl - print "Content-type: text/html\n\n"; - foreach $key (keys %ENV) { - print "$key --> $ENV{$key}<br>"; - } -</pre> - - <h3><a id="stdinandstdout" name="stdinandstdout">STDIN and - STDOUT</a></h3> - - <p>Other communication between the server and the client - happens over standard input (<code>STDIN</code>) and standard - output (<code>STDOUT</code>). In normal everyday context, - <code>STDIN</code> means the keyboard, or a file that a program - is given to act on, and <code>STDOUT</code> usually means the - console or screen.</p> - - <p>When you <code>POST</code> a web form to a CGI program, the - data in that form is bundled up into a special format and gets - delivered to your CGI program over <code>STDIN</code>. The - program then can process that data as though it was coming in - from the keyboard, or from a file</p> - - <p>The ``special format'' is very simple. A field name and its - value are joined together with an equals (=) sign, and pairs of - values are joined together with an ampersand (&). - Inconvenient characters like spaces, ampersands, and equals - signs, are converted into their hex equivalent so that they - don't gum up the works. The whole data string might look - something like:</p> -<pre> - name=Rich%20Bowen&city=Lexington&state=KY&sidekick=Squirrel%20Monkey -</pre> - - <p>You'll sometimes also see this type of string appended to - the a URL. When that is done, the server puts that string into - the environment variable called <code>QUERY_STRING</code>. - That's called a <code>GET</code> request. Your HTML form - specifies whether a <code>GET</code> or a <code>POST</code> is - used to deliver the data, by setting the <code>METHOD</code> - attribute in the <code>FORM</code> tag.</p> - - <p>Your program is then responsible for splitting that string - up into useful information. Fortunately, there are libraries - and modules available to help you process this data, as well as - handle other of the aspects of your CGI program.</p> - <hr /> - - <h2><a id="cgimoduleslibraries" name="cgimoduleslibraries">CGI - modules/libraries</a></h2> - - <p>When you write CGI programs, you should consider using a - code library, or module, to do most of the grunt work for you. - This leads to fewer errors, and faster development.</p> - - <p>If you're writing CGI programs in Perl, modules are - available on <a href="http://www.cpan.org/">CPAN</a>. The most - popular module for this purpose is CGI.pm. You might also - consider CGI::Lite, which implements a minimal set of - functionality, which is all you need in most programs.</p> - - <p>If you're writing CGI programs in C, there are a variety of - options. One of these is the CGIC library, from <a - href="http://www.boutell.com/cgic/">http://www.boutell.com/cgic/</a></p> - <hr /> - - <h2><a id="formoreinformation" name="formoreinformation">For - more information</a></h2> - - <p>There are a large number of CGI resources on the web. You - can discuss CGI problems with other users on the Usenet group - comp.infosystems.www.authoring.cgi. And the -servers mailing - list from the HTML Writers Guild is a great source of answers - to your questions. You can find out more at <a - href="http://www.hwg.org/lists/hwg-servers/">http://www.hwg.org/lists/hwg-servers/</a></p> - - <p>And, of course, you should probably read the CGI - specification, which has all the details on the operation of - CGI programs. You can find the original version at the <a - href="http://hoohoo.ncsa.uiuc.edu/cgi/interface.html">NCSA</a> - and there is an updated draft at the <a - href="http://web.golux.com/coar/cgi/">Common Gateway Interface - RFC project</a>.</p> - - <p>When you post a question about a CGI problem that you're - having, whether to a mailing list, or to a newsgroup, make sure - you provide enough information about what happened, what you - expected to happen, and how what actually happened was - different, what server you're running, what language your CGI - program was in, and, if possible, the offending code. This will - make finding your problem much simpler.</p> - - <p>Note that questions about CGI problems should - <strong>never</strong> be posted to the Apache bug database - unless you are sure you have found a problem in the Apache - source code.</p> - <hr /> - - <h3 align="CENTER">Apache HTTP Server Version 1.3</h3> - <a href="./"><img src="../images/index.gif" alt="Index" /></a> - <a href="../"><img src="../images/home.gif" alt="Home" /></a> - - - </body> -</html> - diff --git a/usr.sbin/httpd/htdocs/manual/howto/cgi.html.ja.jis b/usr.sbin/httpd/htdocs/manual/howto/cgi.html.ja.jis deleted file mode 100644 index 214fa663aa8..00000000000 --- a/usr.sbin/httpd/htdocs/manual/howto/cgi.html.ja.jis +++ /dev/null @@ -1,562 +0,0 @@ -<?xml version="1.0" encoding="iso-2022-jp"?> -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" - "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> -<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja"> - <head> - - <title>Apache Tutorial: CGI $B$K$h$kF0E*%3%s%F%s%D(B</title> - - </head> - <!-- English revision: 1.8 --> - <!-- Background white, links blue (unvisited), navy (visited), red (active) --> - <body bgcolor="#ffffff" text="#000000" link="#0000ff" - vlink="#000080" alink="#ff0000"> - <div align="CENTER"> - <img src="../images/sub.gif" alt="[APACHE DOCUMENTATION]" /> - - <h3>Apache HTTP Server Version 1.3</h3> - </div> - - - - <h1 align="center">CGI $B$K$h$kF0E*%3%s%F%s%D(B</h1> - <a id="__index__" name="__index__"></a> <!-- INDEX BEGIN --> - - - <ul> - <li><a href="#dynamiccontentwithcgi">CGI - $B$K$h$kF0E*%3%s%F%s%D(B</a></li> - - <li> - <a href="#configuringapachetopermitcgi">CGI $B$r5v2D$9$k$h$&$K(B - Apache $B$r@_Dj$9$k(B</a> - - <ul> - <li><a href="#scriptalias">ScriptAlias</a></li> - - <li> - <a href="#cgioutsideofscriptaliasdirectories" - >ScriptAlias $B%G%#%l%/%H%j30$N(B CGI</a> - - <ul> - <li><a - href="#explicitlyusingoptionstopermitcgiexecution">CGI - $B$N<B9T$r2DG=$K$9$k$?$a$K(B Options $B$rL@<(E*$K;HMQ$9$k(B</a></li> - - <li><a href="#htaccessfiles">.htaccess $B%U%!%$%k(B</a></li> - </ul> - </li> - </ul> - </li> - - <li> - <a href="#writingacgiprogram">CGI $B%W%m%0%i%`$r=q$/(B</a> - - <ul> - <li><a href="#yourfirstcgiprogram">$B$"$J$?$N:G=i$N(B CGI - $B%W%m%0%i%`(B</a></li> - </ul> - </li> - - <li> - <a href="#butitsstillnotworking">$B$7$+$7!"$^$@F0$+$J$$(B !</a> - - - <ul> - <li><a href="#filepermissions">$B%U%!%$%k$N%Q!<%_%C%7%g%s(B</a></li> - - <li><a href="#pathinformation">$B%Q%9>pJs(B</a></li> - - <li><a href="#syntaxerrors">$B9=J8%(%i!<(B</a></li> - - <li><a href="#errorlogs">$B%(%i!<%m%0(B</a></li> - </ul> - </li> - - <li> - <a href="#whatsgoingonbehindthescenes" - >$BN"$G2?$,5/$3$C$F$$$k$N$+(B?</a> - - <ul> - <li><a href="#environmentvariables">$B4D6-JQ?t(B</a></li> - - - <li><a href="#stdinandstdout">$BI8=`F~=PNO(B</a></li> - </ul> - </li> - - <li><a href="#cgimoduleslibraries">CGI - $B%b%8%e!<%k(B/$B%i%$%V%i%j(B</a></li> - - <li><a href="#formoreinformation">$B99$J$k>pJs(B</a></li> - </ul> - - <!-- INDEX END --> - <hr /> - - <h2><a id="dynamiccontentwithcgi" name="dynamiccontentwithcgi">CGI - $B$K$h$kF0E*%3%s%F%s%D(B</a></h2> - - <table border="1"> - <tr> - <td valign="top"><strong>$B4XO"%b%8%e!<%k(B</strong><br /> - <br /> - <a href="../mod/mod_alias.html">mod_alias</a><br /> - <a href="../mod/mod_cgi.html">mod_cgi</a><br /> - </td> - - <td valign="top"><strong>$B4XO"%G%#%l%/%F%#%V(B</strong><br /> - <br /> - <a - href="../mod/mod_mime.html#addhandler">AddHandler</a><br /> - <a href="../mod/core.html#options">Options</a><br /> - <a - href="../mod/mod_alias.html#scriptalias">ScriptAlias</a><br /> - </td> - </tr> - </table> - - <p>CGI (Common Gateway Interface) $B$O!"%&%'%V%5!<%P$,(B - $B%3%s%F%s%D@8@.$r$9$k30It%W%m%0%i%`$H6(D4$7$FF0:n$9$k$?$a$NJ}K!$r(B - $BDj5A$7$F$$$^$9!#$=$N%W%m%0%i%`$O$7$P$7$P(B CGI $B%W%m%0%i%`$d(B CGI - $B%9%/%j%W%H$H8F$P$l$^$9!#(BCGI $B$O!"%&%'%V%5%$%H$KF0E*$J%3%s%F%s%D$r(B - $BCV$/$?$a$N:G$b4JC1$G0lHLE*$JJ}K!$G$9!#$3$N%I%-%e%a%s%H$O!"(B - Apache $B%&%'%V%5!<%P$G(B CGI $B$r@_Dj$7!"(B - CGI $B%W%m%0%i%`$r=q$-;O$a$k$?$a$NF~Lg=q$H$J$k$G$7$g$&!#(B</p> - <hr /> - - <h2><a id="configuringapachetopermitcgi" - name="configuringapachetopermitcgi">CGI $B$r5v2D$9$k$h$&$K(B - Apache $B$r@_Dj$9$k(B</a></h2> - - <p>CGI $B%W%m%0%i%`$r@5$7$/F0:n$5$;$k$K$O!"(BCGI $B$r5v2D$9$k$h$&$K(B - Apache $B$N@_Dj$r9T$&I,MW$,$"$j$^$9!#(B - $B$3$l$r9T$J$&$?$a$NJ}K!$,$$$/$D$+$"$j$^$9!#(B</p> - - <h3><a id="scriptalias" name="scriptalias">ScriptAlias</a></h3> - - <p><code>ScriptAlias</code> $B%G%#%l%/%F%#%V$r;HMQ$7$F!"(B - CGI $B%W%m%0%i%`MQ$NFCJL$JJL%G%#%l%/%H%j$r(B Apache $B$K@_Dj$7$^$9!#(B - Apache $B$O!"$3$N%G%#%l%/%H%jCf$NA4$F$N%U%!%$%k$r(B CGI - $B%W%m%0%i%`$G$"$k$H2>Dj$7$^$9!#$=$7$F!"$3$NFCJL$J%j%=!<%9$,(B - $B%/%i%$%"%s%H$+$iMW5a$5$l$k$H!"$=$N%W%m%0%i%`$N<B9T$r;n$_$^$9!#(B</p> - - <p><code>ScriptAlias</code> $B%G%#%l%/%F%#%V$O0J2<$N$h$&$K;HMQ$7$^$9(B:</p> -<pre> - ScriptAlias /cgi-bin/ /usr/local/apache/cgi-bin/ -</pre> - - <p>$B%G%U%)%k%H0LCV$K(B Apache $B$r%$%s%9%H!<%k$7$?$J$i$P!"(B - $B$3$NNc$O%G%U%)%k%H>uBV$N(B <code>httpd.conf</code> - $B@_Dj%U%!%$%k$K4^$^$l$F$$$^$9!#(B<code>ScriptAlias</code> - $B%G%#%l%/%F%#%V$O!"(BURL $B$NA0$KIU2C$9$k%G%#%l%/%H%j$rDj5A$9$k(B - <code>Alias</code> $B%G%#%l%/%F%#%V$H$+$J$j;w$F$$$^$9!#(B - <code>Alias</code> $B$H(B <code>ScriptAlias</code> $B$ODL>o!"(B - <code>DocumentRoot</code> - $B%G%#%l%/%H%j30$N%G%#%l%/%H%j$N$?$a$K;HMQ$5$l$^$9!#(B - <code>Alias</code> $B$H(B <code>ScriptAlias</code> $B$H$N:9$O!"(B - <code>ScriptAlias</code> $B$,@\F,<-$G;O$^$k$9$Y$F$N(B URL $B$O(B CGI - $B%W%m%0%i%`$H$_$J$5$l$k$H$$$&DI2C$N0UL#$r4^$s$G$$$k$3$H$G$9!#(B - $B=>$C$F!">e5-$NNc$G$O!"(B<code>/cgi-bin/</code> - $B$G;O$^$k%j%=!<%9$X$N$"$i$f$k%j%/%(%9%H$KBP$7$F!"%G%#%l%/%H%j(B - <code>/usr/local/apache/cgi-bin/</code> $B$+$iDs6!$7!"$=$l$i$r(B - CGI $B%W%m%0%i%`$H$7$F07$&$h$&(B Apache $B$K<($7$^$9!#(B</p> - - <p>$BNc$($P!"(BURL <code>http://dev.rcbowen.com/cgi-bin/test.pl</code> - $B$,MW5a$5$l$?>l9g!"(BApache $B$O(B $B%U%!%$%k(B - <code>/usr/local/apache/cgi-bin/test.pl</code> - $B$r<B9T$7!"$=$N=PNO$rJV$9$3$H$r;n$_$^$9!#(B - $B$b$A$m$s!"%U%!%$%k$,B8:_$7!"<B9T2DG=$G$"$j!"(B - $B7h$a$i$l$?J}K!$G=PNO$rJV$7$^$9!#(B - $B$=$&$G$J$1$l$P!"(BApache $B$O%(%i!<%a%C%;!<%8$rJV$7$^$9!#(B</p> - - <h3><a id="cgioutsideofscriptaliasdirectories" - name="cgioutsideofscriptaliasdirectories"> - ScriptAlias $B%G%#%l%/%H%j30$N(B CGI</a></h3> - - <p>CGI $B%W%m%0%i%`$O!"%;%-%e%j%F%#>e$NM}M3$+$i(B <code>ScriptAlias</code> - $B$5$l$?%G%#%l%/%H%j$K@)8B$5$l$k$3$H$,$7$P$7$P$"$j$^$9!#$3$NJ}K!$K$h$j!"(B - CGI $B%W%m%0%i%`$r;HMQ$G$-$k%f!<%6$r4IM}<T$,87$7$/@)8f$9$k$3$H$,$G$-$^$9!#(B - $B$7$+$7$J$,$i!"E,@Z$J%;%-%e%j%F%#;vA0BP:v$,$H$i$l$k$J$i$P!"(BCGI - $B%W%m%0%i%`$rG$0U$N%G%#%l%/%H%j$G<B9T$G$-$J$$$h$&$K$9$kM}M3$O$"$j$^$;$s!#(B - $BNc$($P!"%f!<%6$K(B <code>UserDir</code> $B%G%#%l%/%F%#%V$G(B - $BH`$i$N%[!<%`%G%#%l%/%H%jG[2<$K%&%'%V%3%s%F%s%D$r;}$?$;$?$$$H$7$^$9!#(B - $B$b$7!"H`$i$,(B CGI $B%W%m%0%i%`$r;}$D$3$H$rK>$s$G$$$F$b!"%a%$%s$N(B - <code>cgi-bin</code> $B%G%#%l%/%H%j$X$N%"%/%;%9$,$G$-$J$$>l9g!"(BCGI - $B%W%m%0%i%`$r<B9T$9$k$3$H$,$G$-$kB>$N>l=j$,I,MW$K$J$j$^$9!#(B - </p> - - <h3><a id="explicitlyusingoptionstopermitcgiexecution" - name="explicitlyusingoptionstopermitcgiexecution"> - CGI $B$N<B9T$r2DG=$K$9$k$?$a$K(B Options $B$rL@<(E*$K;HMQ$9$k(B</a></h3> - - <p>$B%5!<%P$N%a%$%s$N@_Dj%U%!%$%kCf$G(B <code>Options</code> - $B%G%#%l%/%F%#%V$rL@<(E*$K;HMQ$9$k$3$H$G!"FCDj$N%G%#%l%/%H%jG[2<$G(B - CGI $B$N<B9T$r5v2D$9$k$h$&$K;XDj$9$k$3$H$,$G$-$^$9(B:</p> -<pre> - <Directory /usr/local/apache/htdocs/somedir> - Options +ExecCGI - </Directory> -</pre> - - <p>$B>e5-%G%#%l%/%F%#%V$O!"(BCGI $B%U%!%$%k$N<B9T$r2DG=$K$9$k$h$&(B Apache - $B$KEA$($^$9!#$^$?!"$I$N%U%!%$%k$,(B CGI $B%U%!%$%k$+$r%5!<%P$KEA$($k(B - $BI,MW$,$"$j$^$9!#<!$N(B <code>AddHandler</code> $B%G%#%l%/%F%#%V$NNc$G$O!"(B - <code>cgi</code> $B$^$?$O(B <code>pl</code> $B$r3HD%;R$K;}$D$9$Y$F$N%U%!%$%k$r(B - CGI $B%W%m%0%i%`$H$7$F$_$J$9$3$H$r%5!<%P$KEA$($^$9(B:</p> -<pre> - AddHandler cgi-script cgi pl -</pre> - - <h3><a id="htaccessfiles" - name="htaccessfiles">.htaccess $B%U%!%$%k(B</a></h3> - - <p><code>.htaccess</code> - $B%U%!%$%k$O!"%G%#%l%/%H%jKh$K%G%#%l%/%F%#%V$r;XDj$9$kJ}K!$G$9!#(BApache - $B$O!"%j%=!<%9$rDs6!$9$k$H$-$K!"Ds6!$9$k%U%!%$%k$,CV$+$l$F$$$k%G%#%l%/%H%jCf$N(B - <code>.htaccess</code> $B$H$$$&%U%!%$%k$r;2>H$7$^$9!#$=$N%U%!%$%k$rH/8+$7$?$i!"(B - $B$=$NCf$GH/8+$5$l$?%G%#%l%/%F%#%V$,E,MQ$5$l$^$9!#(B<code>.htaccess</code> - $B%U%!%$%k$O!"(B<code>AllowOverride</code> $B%G%#%l%/%F%#%V$N;XDj$K$h$j(B - $B;H$($k$h$&$K$J$j$^$9!#(B<code>AllowOverride</code>$B%G%#%l%/%F%#%V$O!"(B - <code>.htaccess</code> $B%U%!%$%k$G@_Dj$G$-$k%G%#%l%/%F%#%V$N%?%$%W$r;XDj$7$^$9!#(B - <code>AllowOverride</code> $B%G%#%l%/%F%#%V$N;XDj$,$J$$>l9g!"$^$C$?$/;H$($^$;$s!#(B - CGI $B$N<B9T$r5v2D$9$k$?$a$KI,MW$H$J$k%G%#%l%/%F%#%V$r;XDj2DG=$K$9$k$K$O!"(B - $B0J2<$N@_Dj$,%5!<%P$N%a%$%s$N@_Dj$GI,MW$K$J$j$^$9(B:</p> -<pre> - AllowOverride Options -</pre> - - <p><code>.htaccess</code> $B%U%!%$%k$G$O!"<!$N%G%#%l%/%F%#%V$,I,MW$H(B - $B$J$j$^$9(B:</p> -<pre> - Options +ExecCGI -</pre> - - <p>$B$3$N@_Dj$G$O!"$3$N%G%#%l%/%H%j$K$*$1$k(B - CGI $B%W%m%0%i%`$N<B9T$r5v2D$9$k$h$&(B Apache $B$KEA$($^$9!#(B</p> - <hr /> - - <h2><a id="writingacgiprogram" - name="writingacgiprogram">CGI $B%W%m%0%i%`$r=q$/(B</a></h2> - - <p>$BDL>o$N%W%m%0%i%_%s%0$H(B - CGI $B%W%m%0%i%_%s%0$N4V$K$O<g$KFs$D$N0c$$$,$"$j$^$9!#(B</p> - - <p>$B0l$D$O!"(BCGI $B%W%m%0%i%`$N$9$Y$F$N=PNO$K$O(B MIME-type - $B%X%C%@$rIU$1$J$1$l$P$J$j$^$;$s!#$3$l$O$I$N$h$&$J<oN`$N%3%s%F%s%D(B - $B$r<u$1<h$C$F$$$k$+$r%/%i%$%"%s%H$K<($9(B HTTP $B%X%C%@$G$9!#(B - $B$[$H$s$I$N>l9g$G$O!"<!$N$h$&$K=PNO$7$^$9(B:</p> -<pre> - Content-type: text/html -</pre> - - <p>$B$b$&0l$D$O!"=PNO$r(B HTML $B$+!"(B - $B%V%i%&%6$,I=<($9$k$3$H$,$G$-$k2?$+B>$N7A<0$K$9$kI,MW$,$"$j$^$9!#(B - $BBgDq$N>l9g$O(B HTML $B$G$7$g$&$,!"(BGIF $B%$%a!<%8$dB>$NHs(B HTML - $B%3%s%F%s%D$r=PNO$9$k(B CGI $B%W%m%0%i%`$r=q$/$3$H$b$"$k$G$7$g$&!#(B - </p> - - <p>$B$3$l$iFsE@0J30$G$O!"(BCGI $B%W%m%0%i%`$r=q$/$3$H$O!"(B - $B$"$J$?$,=q$$$F$$$kB>$N%W%m%0%i%`$HBg$$$K;w$F$$$k$G$7$g$&!#(B</p> - - <h3><a id="yourfirstcgiprogram" - name="yourfirstcgiprogram">$B$"$J$?$N:G=i$N(B CGI $B%W%m%0%i%`(B</a></h3> - - <p>$B<!$K<($9$N$O!"%V%i%&%6$K(B 1 $B9T0u;z$9$k(B CGI $B%W%m%0%i%`$NNc$G$9!#(B - $B0J2<$rF~NO$7!"(B<code>first.pl</code> $B$H$$$&%U%!%$%k$KJ]B8$7!"(B - $B$=$l$r(B <code>cgi-bin</code> $B%G%#%l%/%H%j$KCV$$$F$/$@$5$$!#(B - </p> -<pre> - #!/usr/bin/perl - print "Content-type: text/html\r\n\r\n"; - print "Hello, World."; -</pre> - - <p>Perl $B$K@:DL$7$F$$$J$/$F$b!"(B - $B2?$,5/$3$k$+$rM}2r$9$k$3$H$O$G$-$k$O$:$G$9!#(B - 1 $B9TL\$O!"(B<code>/usr/bin/perl</code> $B$G8+$D$1$i$l$k%$%s%?%W%j%?(B - $B$K$3$N%U%!%$%k$r6!5k$9$k$3$H$G$3$N%W%m%0%i%`$,<B9T$5$l$k$3$H$r(B - Apache $B$K(B ($B%7%'%k>e$G<B9T$7$h$&$H$7$F$$$k$J$i$P!"$=$N%7%'%k$K(B ) - $B<($7$^$9!#(B2 $B9TL\$O!"A0=R$7$?$H$*$j(B content-type - $B$NDj5A$r0u;z$7$^$9!#$3$l$K$OI|5"2~9T$NFs$D$NAH$r8e$KIU2C$7$^$9!#(B - $B$3$l$K$h$j!"%X%C%@$N=*$j$K6u9T$,CV$+$l!"(B - HTTP $B%X%C%@$N=*$j$H%\%G%#$N;O$^$j$r<($7$^$9!#(B3 $B9TL\$O!"(B - ``Hello, World.'' $B$H$$$&J8;zNs$r0u;z$7!"$3$l$G=*$j$H$J$j$^$9!#(B</p> - - <p>$B9%$_$N%V%i%&%6$r3+$-!"%"%I%l%9(B</p> -<pre> - http://www.example.com/cgi-bin/first.pl -</pre> - - <p>$B$"$k$$$O%U%!%$%k$rCV$$$?%m%1!<%7%g%s$r;XDj$9$k$H!"(B - <code>Hello, World.</code> $B$H$$$&(B 1 $B9T$,%V%i%&%6%&%#%s%I(B - $B$K8=$l$k$G$7$g$&!#$=$l$O$"$^$j%(%-%5%$%F%#%s%0$J$3$H$G$O$"$j$^$;$s!#(B - $B$7$+$7!"$3$l$,$&$^$/F0$1$P!"(B - $BB>$N$I$N$h$&$J$b$N$G$bF0$+$9$3$H$,$G$-$k$h$&$K$J$j$^$9!#(B</p> - <hr /> - - <h2><a id="butitsstillnotworking" - name="butitsstillnotworking">$B$7$+$7!"$^$@F0$+$J$$(B !</a></h2> - - <p>$B%&%'%V$+$i(B CGI $B%W%m%0%i%`$X$N%"%/%;%9$r9T$J$C$?$H$-!"(B - $B%V%i%&%6$G8+$k2DG=@-$,$"$k;M$D$N4pK\E*$J$3$H$,$"$j$^$9(B:</p> - - <dl> - <dt>CGI $B%W%m%0%i%`$N=PNO(B</dt> - - <dd>$BAG@2$i$7$$(B ! $B$=$l$O$9$Y$F$,$&$^$/F0$$$?$3$H$r0UL#$7$^$9!#(B<br /> - <br /> - </dd> - - <dt>CGI $B%W%m%0%i%`$N%=!<%9%3!<%I!"$^$?$O(B - "POST Method Not Allowed" $B$H$$$&%a%C%;!<%8(B</dt> - - <dd>$B$3$l$O!"(BCGI $B%W%m%0%i%`$r=hM}$G$-$k$h$&(B - Apache $B$rE,@Z$K@_Dj$7$F$$$J$+$C$?$3$H$r0UL#$7$^$9!#(B - <a href="#configuringapachetopermitcgi">$B!V(BCGI $B$r5v2D$9$k$h$&$K(B - Apache $B$r@_Dj$9$k!W(B</a>$B$N>O$rFI$_D>$7!"(B - $B$"$J$?$,2?$r4V0c$($?$+$rC5$7$F$_$F$/$@$5$$!#(B<br /> - <br /> - </dd> - - <dt>$B%a%C%;!<%8$,(B "Forbidden" $B$G;O$^$C$F$$$k(B</dt> - - <dd>$B$3$l$O%Q!<%_%C%7%g%s$NLdBj$H$$$&$3$H$r0UL#$7$^$9!#(B - <a href="#errorlogs">Apache $B$N%(%i!<%m%0(B</a>$B$H!"8e=R$N(B - <a href="#filepermissions">$B!V%U%!%$%k$N%Q!<%_%C%7%g%s!W(B</a>$B$N>O$r(B - $B%A%'%C%/$7$F$/$@$5$$!#(B<br /> - <br /> - </dd> - - <dt>"Internal Server Error" $B$H$$$&%a%C%;!<%8(B</dt> - - <dd><a href="#errorlogs">Apache $B$N%(%i!<%m%0(B</a>$B$r%A%'%C%/$9$k$H!"(B - "Premature end of script headers" $B$H$$$&%m%0$,5-O?$5$l$F$$$k$H;W$$$^$9!#(B - $B$=$7$F!"$*$=$i$/(B CGI $B%W%m%0%i%`$K$h$C$F@8@.$5$l$?%(%i!<%a%C%;!<%8(B - $B$b5-O?$5$l$F$$$k$G$7$g$&!#$3$N>l9g!"(BCGI $B%W%m%0%i%`$,E,@Z$J(B - HTTP $B%X%C%@$r=PNO$G$-$J$$860x$rCN$k$?$a$K!"(B - $B0J2<$N3F>O$G%A%'%C%/$7$F$_$F$/$@$5$$!#(B - </dd> - </dl> - - <h3><a id="filepermissions" - name="filepermissions">$B%U%!%$%k$N%Q!<%_%C%7%g%s(B</a></h3> - - <p>$B%5!<%P$O$"$J$?$N8"8B$G<B9T$5$l$F$$$J$$$N$rK:$l$J$$$h$&$K!#(B - $B$D$^$j!"5/F0$9$k$H$-!"%5!<%P$OFC8"$r$b$?$J$$%f!<%6(B - $BDL>o(B - ``nobody'' $B$d(B ``www'' $B$N8"8B$G<B9T$5$l$^$9!#$7$?$,$C$F!"(B - $B$"$J$?$,=jM-$9$k%U%!%$%k$r<B9T$9$k$K$OJL$N%Q!<%_%C%7%g%s(B - $B$,I,MW$H$J$j$^$9!#DL>o!"(B``nobody'' $B$,<B9T$9$k$N$K==J,$J(B - $B%Q!<%_%C%7%g%s$rM?$($kJ}K!$O!"%U%!%$%k$KC/$G$b<B9T2DG=$H$9$k(B - $B%Q!<%_%C%7%g%s$rM?$($k$3$H$G$9(B:</p> -<pre> - chmod a+x first.pl -</pre> - - <p>$B$^$?!"$b$7$"$J$?$N%W%m%0%i%`$,B>$N%U%!%$%k$rFI$_=q$-$9$k$J$i$P!"(B - $B$=$l$i$N%U%!%$%k$O!"$3$l$,2DG=$H$J$k@5$7$$%Q!<%_%C%7%g%s(B - $B$r;}$C$F$$$kI,MW$,$"$j$^$9!#(B</p> - - <p>$B$3$l$KBP$9$kNc30$O!"%5!<%P$,(B <a href="../suexec.html">suexec</a> - $B$r;HMQ$9$k$h$&@_Dj$5$l$F$$$k>l9g$G$9!#(Bsuexec $B$O!"(BCGI - $B%W%m%0%i%`$,CV$+$l$F$$$k%P!<%A%c%k%[%9%H$^$?$O%f!<%6$N(B - $B%[!<%`%G%#%l%/%H%j$K$h$C$F!"0[$J$k%f!<%68"8B$G<B9T$5$l$k$h$&$K$7$^$9!#(B - suexec $B$O$H$F$b87$7$$%Q!<%_%C%7%g%s$N%A%'%C%/$,$"$j!"(B - $B$=$N%A%'%C%/$rDL2a$G$-$J$$$H(B "Internal Server Error" $B$H$J$j!"$=$N(B - CGI $B%W%m%0%i%`$N<B9T$O<:GT$7$^$9!#(B - $B$3$N>l9g!"$I$N%;%-%e%j%F%#%A%'%C%/$,<:GT$7$F$$$k$N$+$rCN$k$?$a$K(B - suexec $B%m%0%U%!%$%k$r%A%'%C%/$9$kI,MW$,$"$j$^$9!#(B</p> - - <h3><a id="pathinformation" - name="pathinformation">$B%Q%9>pJs(B</a></h3> - - <p>$B%3%^%s%I%i%$%s$+$i%W%m%0%i%`$r<B9T$9$k$H$-!"(B - $B0U<1$7$J$/$F$b%7%'%k$KEO$5$l$k>pJs$,$"$j$^$9!#(B - $BNc$($P!";2>H$9$k%U%!%$%k$N$?$a$K$I$3$r8!:w$7$?$i$h$$$+$r(B - $B%7%'%k$KEA$($k%Q%9$,$"$j$^$9!#(B</p> - - <p>$B%W%m%0%i%`$,(B CGI $B%W%m%0%i%`$H$7$F%&%'%V%5!<%P$K$h$C$F<B9T$5$l$k$H$-!"(B - $B$=$l$O%Q%9$r;}$A$^$;$s!#(BCGI $B%W%m%0%i%`Fb$G8F$S=P$9$"$i$f$k%W%m%0%i%`(B - ($BNc$($P!"(B'sendmail' $B$N$h$&$J$b$N(B) $B$O!"%U%k%Q%9$G;XDj$9$kI,MW$,$"$k$G$7$g$&!#(B - $B$=$l$K$h$j!"(BCGI $B%W%m%0%i%`$r<B9T$7$h$&$H$7$?$H$-!"(B - $B%7%'%k$O$=$N$h$&$J%W%m%0%i%`$r8+$D$1$k$3$H$,$G$-$^$9!#(B</p> - - <p>$BF1MM$J$3$H$O!"%9%/%j%W%H$N%$%s%?%W%j%?(B ($B$7$P$7$P(B <code> perl - </code>) $B$X$N%Q%9$G!"(BCGI $B%W%m%0%i%`$N(B 1 $B9TL\$K<!$N$h$&$K<($5$l$^$9(B:</p> - -<pre> - #!/usr/bin/perl -</pre> - - <p>$B$3$l$,%$%s%?!<%W%j%?$X$N<B:]$N%Q%9$G$"$k$3$H$r3N<B$K$7$F$*$-$^$9!#(B</p> - - - <h3><a id="syntaxerrors" - name="syntaxerrors">$B9=J8%(%i!<(B</a></h3> - - <p>CGI $B%W%m%0%i%`$,<:GT$9$k$N$OBgDq!"(B - $B%W%m%0%i%`<+?H$KLdBj$,$"$k>l9g$G$9!#0lEY(B CGI $B$N;H$$J}$rM}2r$7!"(B - $BA0=R$NFs$D$N8m$j$rHH$7$F$$$J$$$J$i$P!"$^$:4V0c$$$J$/$=$&$G$7$g$&!#(B - $B%V%i%&%6$rDL$7$F%F%9%H$r9T$&A0$KI,$:!"%3%^%s%I%i%$%s$+$i(B - $B%W%m%0%i%`$N<B9T$r;n$7$F$/$@$5$$!#(B - $B$3$l$K$h$j!"BgDq$NLdBj$,5/$3$i$J$/$J$j$^$9!#(B</p> - - <h3><a id="errorlogs" name="errorlogs">$B%(%i!<%m%0(B</a></h3> - - <p>$B%(%i!<%m%0$OM'C#$G$9!#A4$F$N$&$^$/$$$+$J$$$3$H$O!"(B - $B%(%i!<%m%0$K%a%C%;!<%8$r@8@.$7$^$9!#I,$:$=$l$r:G=i$K8+$k$Y$-$G$9!#(B - $B$b$7!"$"$J$?$,%&%'%V%5%$%H$r<g:E$7$F$$$k>l=j$,%(%i!<%m%0$N;2>H$r(B - $B5v$7$F$$$J$$$J$i$P!"$-$C$HB>$N%5%$%H$G<g:E$9$k$Y$-$G$9!#(B - $B%(%i!<%m%0$NFI$_J}$r3X$V$3$H$G!"$[$H$s$IA4$F$NLdBj$,?WB.$K3NG'$5$l!"(B - $B?WB.$K2r7h$5$l$k$H$$$&$3$H$,J,$+$k$G$7$g$&!#(B - </p> - <hr /> - - <h2><a id="whatsgoingonbehindthescenes" - name="whatsgoingonbehindthescenes">$BN"$G2?$,5/$3$C$F$$$k$N$+(B?</a></h2> - - - <p>CGI $B%W%m%0%i%_%s%0$K=OC#$9$k$H!"(B - $BN"$G5/$3$C$F$$$k$3$H$K$D$$$F99$KM}2r$9$k$3$H$OM-1W$K$J$k$G$7$g$&!#(B - $B%V%i%&%6$H%5!<%P$,$I$N$h$&$KAj8_DL?.$9$k$+$K$D$$$F$OFC$K$=$&$G$9!#(B - $B$J$<$J$i!"(B``Hello, World.'' - $B$r0u;z$9$k%W%m%0%i%`$r=q$/$3$H$O$^$3$H$K7k9=$G$9$,!"(B - $B$=$l$OFC$KM-1W$G$O$"$j$^$;$s!#(B</p> - - <h3><a id="environmentvariables" - name="environmentvariables">$B4D6-JQ?t(B</a></h3> - - <p>$B4D6-JQ?t$O!"$"$J$?$,%3%s%T%e!<%?$r;H$&$H$-$KJU$j$KB8:_$7$F$$$kCM$G$9!#(B - $B$=$l$i$O!"%Q%9(B - ($B%3%^%s%I$r%?%$%W$7$?$H$-$K<B9T$9$k<B:]$N%U%!%$%k$rC5$7=P$9$H$3$m(B)$B!"(B - $B%f!<%6L>!"C<Kv7?$J$I$N$h$&$JJXMx$J$b$N$G$9!#(B - $BDL>o$N!"KhF|$N4D6-JQ?t$N40A4$J%j%9%H$rD4$Y$k$K$O!"(B - $B%3%^%s%I%W%m%s%W%H$G(B <code>env</code> $B$rF~NO$7$^$9!#(B</p> - - <p>CGI $B$N=hM}Cf!"%5!<%P$H%V%i%&%6$b4D6-JQ?t$r@_Dj$7!"(B - $B$=$l$K$h$jAj8_$KDL?.$9$k$3$H$,$G$-$k$h$&$K$J$j$^$9!#(B - $B$=$N4D6-JQ?t$O!"%V%i%&%6%?%$%W(B (Netscape, IE, Lynx)$B!"(B - $B%5!<%P%?%$%W(B (Apache, IIS, WebSite)$B!"<B9T$5$l$F$$$k(B - CGI $B%W%m%0%i%`$NL>A0$J$I$N$h$&$J$b$N$G$9!#(B</p> - - <p>$B$3$l$i$NJQ?t$O(B CGI $B%W%m%0%i%^$,;HMQ$9$k$3$H$,$G$-$^$9!#(B - $B$=$7$F!"$=$l$O%/%i%$%"%s%H$H%5!<%P$NDL?.$NOC$NH>J,$G$9!#(B - $BI,MW$JJQ?t$N40A4$J%j%9%H$O(B <a - href="http://hoohoo.ncsa.uiuc.edu/cgi/env.html" - >http://hoohoo.ncsa.uiuc.edu/cgi/env.html</a> $B$K$"$j$^$9!#(B</p> - - <p>$B0J2<$NC1=c$J(B Perl CGI $B%W%m%0%i%`$O!"(B - $BEO$5$l$kA4$F$N4D6-JQ?t$rI=<($7$^$9!#F1MM$N%W%m%0%i%`$O!"(B - Apache $B%G%#%9%H%j%S%e!<%7%g%s$N(B <code>cgi-bin</code> - $B%G%#%l%/%H%j$KFs$D4^$^$l$F$$$^$9!#$$$/$D$+$NJQ?t$,I,?\$G$"$j!"(B - $B$$$/$D$+$OG$0U$G$"$k$3$H$KCm0U$7$F$/$@$5$$!#$=$7$F!"(B - $B8x<0$N%j%9%H$K$O$J$$$$$/$D$+$NJQ?t$,I=<($5$l$F$$$k$+$b$7$l$^$;$s!#(B - $B$5$i$K!"(BApache $B$O%G%U%)%k%H$GMQ0U$5$l$F$$$k4pK\E*$J$b$N$K(B - <a href="../env.html">$B$"$J$?<+?H$N4D6-JQ?t$r2C$($k(B</a>$B$?$a$N!"(B - $BB?$/$N0[$J$kJ}K!$rMQ0U$7$F$7$^$9!#(B</p> -<pre> - #!/usr/bin/perl - print "Content-type: text/html\n\n"; - foreach $key (keys %ENV) { - print "$key --> $ENV{$key}<br>"; - } -</pre> - - <h3><a id="stdinandstdout" name="stdinandstdout">STDIN $B$H(B - STDOUT</a></h3> - - <p>$B%5!<%P$H%/%i%$%"%s%H4V$N$b$&0l$D$NDL?.$O!"I8=`F~NO(B - (<code>STDIN</code>)$B$HI8=`=PNO(B (<code>STDOUT</code>) - $B$rDL$8$F9T$J$o$l$^$9!#DL>o$NJ8L.$K$*$$$F!"(B<code>STDIN</code> - $B$O%-!<%\!<%I$d%W%m%0%i%`$,F0:n$9$k$?$a$KM?$($i$l$k%U%!%$%k$r0UL#$7!"(B - <code>STDOUT</code> $B$ODL>o%3%s%=!<%k$^$?$O%9%/%j!<%s$r0UL#$7$^$9!#(B - </p> - - <p>$B%&%'%V%U%)!<%`$+$i(B CGI $B%W%m%0%i%`$X(B<code>POST</code> $B$7$?$H$-!"(B - $B%U%)!<%`$N%G!<%?$OFCJL$J%U%)!<%^%C%H$GB+$M$i$l!"(B<code>STDIN</code> - $B$rDL$7$F!"(BCGI $B%W%m%0%i%`$K0z$-EO$5$l$^$9!#(B - $B%W%m%0%i%`$O%G!<%?$,%-!<%\!<%I$b$7$/$O%U%!%$%k(B - $B$+$iMh$F$$$?$+$N$h$&$K=hM}$9$k$3$H$,$G$-$^$9!#(B</p> - - <p>$B!VFCJL$J%U%)!<%^%C%H!W$O$H$F$bC1=c$G$9!#%U%#!<%k%IL>$HCM$O(B - $B%$%3!<%k(B (=) $B$G7k$P$l$^$9!#$=$7$FCM$NAH$O%"%s%Q%5%s%I(B (&) - $B$G7k$P$l$^$9!#%9%Z!<%9!"%"%s%Q%5%s%I!"%$%3!<%k$N$h$&$JLLE]$JJ8;z$O!"(B - $B$=$l$i$,F0:n$rBLL\$K$7$J$$$h$&$K$=$NJ8;z$KAjEv$9$k(B - 16 $B?J$KJQ49$5$l$^$9!#A4%G!<%?J8;zNs$O!"0J2<$N$h$&$K$J$j$^$9(B: - </p> - -<pre> - name=Rich%20Bowen&city=Lexington&state=KY&sidekick=Squirrel%20Monkey -</pre> - - <p>$B;~!9!"$3$N$h$&$JJ8;zNs$,(B URL $B$KIU2C$5$l$k$N$r8+$k$G$7$g$&!#(B - $B$=$N>l9g!"%5!<%P$O(B <code>QUERY_STRING</code> - $B$H$$$&4D6-JQ?t$K$=$NJ8;zNs$rF~$l$^$9!#$=$l$O(B <code>GET</code> - $B%j%/%(%9%H$H8F$P$l$^$9!#(BHTML $B%U%)!<%`$G$O!"%G!<%?$rEO$9$?$a$K(B - <code>GET</code> $B$H(B <code>POST</code> $B$N$I$A$i$r;HMQ$9$k$+$r!"(B - <code>FORM</code>$B%?%0$N(B <code>METHOD</code> - $BB0@-$N@_Dj$G;XDj$7$^$9!#(B</p> - - <p>CGI $B%W%m%0%i%`$O!"$=$NJ8;zNs$rLr$KN)$D>pJs$KJ,3d$9$k@UG$$,$"$j$^$9!#(B - $B9,$$$K$b!"$=$N%G!<%?=hM}$r=u$1$k%i%$%V%i%j$d%b%8%e!<%k$,B8:_$7$^$9!#(B - $B$3$l$i$O!"(BCGI $B%W%m%0%i%`$NB>$NLL$G$bF1MM$KLr$KN)$A$^$9!#(B - </p> - <hr /> - - <h2><a id="cgimoduleslibraries" - name="cgimoduleslibraries">CGI $B%b%8%e!<%k(B/$B%i%$%V%i%j(B</a></h2> - - <p>CGI $B%W%m%0%i%`$r=q$/$H$-!"LLE]$J;E;v$NBgItJ,$r$7$F$/$l$k(B - $B%3!<%I%i%$%V%i%j$^$?$O%b%8%e!<%k$r;H$&$3$H$r8!F$$9$Y$-$G$9!#(B - $B$3$l$O%(%i!<$r8:$i$7!"Aa$$3+H/$K$D$J$,$j$^$9!#(B</p> - - <p>Perl $B$G(B CGI $B%W%m%0%i%`$r=q$$$F$$$k$J$i!"%b%8%e!<%k$O(B - <a href="http://www.cpan.org/">CPAN</a> $B$GDs6!$5$l$F$$$^$9!#(B - $B$3$NL\E*$N$?$a$N:G$bIa5Z$7$F$$$k%b%8%e!<%k$O(B CGI.pm $B$G$9!#(B - CGI::Lite $B$b8!F$$7$^$7$g$&!#$3$l$O!"$[$H$s$I$N%W%m%0%i%`(B - $B$K$*$$$FI,MW$H$9$k$9$Y$F$N5!G=$N:G>.%;%C%H$N<BAu$G$9!#(B</p> - - <p>C $B$G(B CGI $B%W%m%0%i%`$r=q$$$F$$$k$J$i!"$$$m$$$m$J%*%W%7%g%s$,$"$j$^$9!#(B - $B$3$l$i$NFb$N0l$D$O(B <a href="http://www.boutell.com/cgic/" - >http://www.boutell.com/cgic/</a> $B$GDs6!$5$l$F$$$k(B CGIC $B%i%$%V%i%j$G$9!#(B</p> - <hr /> - - <h2><a id="formoreinformation" - name="formoreinformation">$B99$J$k>pJs(B</a></h2> - - <p>CGI $B$K4X$9$k>pJs$O%&%'%V$G?tB?$/Ds6!$5$l$F$$$^$9!#(B - CGI $B$NLdBj$K$D$$$F$O(B Usenet $B$N(B comp.infosystems.www.authoring.cgi - $B$G!"B>$N%f!<%6$HO@5D$9$k$3$H$,$G$-$^$9!#(BHTML Writers Guide $B$N(B -servers - $B%a!<%j%s%0%j%9%H$O!"$"$J$?$N<ALd$K2sEz$7$F$/$l$k0NBg$J%j%=!<%9$G$9!#(B - <a href="http://www.hwg.org/lists/hwg-servers/" - >http://www.hwg.org/lists/hwg-servers/</a> $B$G99$KB?$/$rC5$7=P$9$3$H$,$G$-$^$9!#(B</p> - - <p>$B$=$7$F$b$A$m$s!"$*$=$i$/(B CGI - $B%W%m%0%i%`$NF0:n$K4X$9$k>\:Y$NA4$F$,5-=R$5$l$F$$$k(B CGI - $B$N;EMM$rFI$`$Y$-$G$9!#%*%j%8%J%k%P!<%8%g%s$r(B <a - href="http://hoohoo.ncsa.uiuc.edu/cgi/interface.html">NCSA</a> $B$G!"(B - $B%"%C%W%G!<%H$5$l$?%I%i%U%H$r(B <a - href="http://web.golux.com/coar/cgi/">Common Gateway Interface RFC - $B%W%m%8%'%/%H(B</a>$B$G;2>H$9$k$3$H$,$G$-$^$9!#(B</p> - - <p>CGI $B$NLdBj$K$D$$$F!"(B - $B2C$o$C$F$$$k%a!<%j%s%0%j%9%H$^$?$O%K%e!<%9%0%k!<%W$K<ALd$rAw$k$H$-!"(B - $B5/$3$C$?$b$N!"5/$3$C$F$[$7$$$3$H!"<B:]$K5/$3$C$?$3$H$,$I$&0c$&$+!"(B - $B;HMQ$7$F$$$k%5!<%P!"(BCGI - $B%W%m%0%i%`$r5-=R$7$F$$$k8@8l$K4X$9$k==J,$J>pJs$H!"(B - $B2DG=$G$"$l$PLdBj$N%3!<%I$rDs6!$9$k$h$&$K$7$F$/$@$5$$!#(B - $B$=$&$9$k$3$H$G!"LdBj$,$h$j4VC1$K8+$D$+$k$h$&$K$J$j$^$9!#(B</p> - - <p>Apache - $B$N%=!<%9%3!<%I$K$*$$$FLdBj$rH/8+$7$?$3$H$r3N?.$7$F$$$J$$8B$j!"(B - CGI $B$NLdBj$K4X$9$k<ALd$r(B Apache - $B%P%0%G!<%?%Y!<%9$KAw$k$Y$-$G$J$$$3$H$KCmL\$7$F$/$@$5$$!#(B</p> - <hr /> - - <h3 align="CENTER">Apache HTTP Server Version 1.3</h3> - <a href="./"><img src="../images/index.gif" alt="Index" /></a> - <a href="../"><img src="../images/home.gif" alt="Home" /></a> - - - </body> -</html> diff --git a/usr.sbin/httpd/htdocs/manual/howto/ssi.html.en b/usr.sbin/httpd/htdocs/manual/howto/ssi.html.en deleted file mode 100644 index 046386cf77e..00000000000 --- a/usr.sbin/httpd/htdocs/manual/howto/ssi.html.en +++ /dev/null @@ -1,554 +0,0 @@ -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" - "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> - -<html xmlns="http://www.w3.org/1999/xhtml"> - <head> - <meta name="generator" content="HTML Tidy, see www.w3.org" /> - - <title>Apache Tutorial: Introduction to Server Side - Includes</title> - </head> - <!-- Background white, links blue (unvisited), navy (visited), red (active) --> - - <body bgcolor="#FFFFFF" text="#000000" link="#0000FF" - vlink="#000080" alink="#FF0000"> - <div align="CENTER"> - <img src="../images/sub.gif" alt="[APACHE DOCUMENTATION]" /> - - <h3>Apache HTTP Server Version 1.3</h3> - </div> - - - - <h1 align="CENTER">Apache Tutorial: Introduction to Server Side - Includes</h1> - <a id="__index__" name="__index__"></a> <!-- INDEX BEGIN --> - - - <ul> - <li><a - href="#apachetutorial:introductiontoserversideincludes">Apache - Tutorial: Introduction to Server Side Includes</a></li> - - <li><a href="#whataressi">What are SSI?</a></li> - - <li><a href="#configuringyourservertopermitssi">Configuring - your server to permit SSI</a></li> - - <li> - <a href="#basicssidirectives">Basic SSI directives</a> - - <ul> - <li><a href="#today'sdate">Today's date</a></li> - - <li><a href="#modificationdateofthefile">Modification - date of the file</a></li> - - <li><a href="#includingtheresultsofacgiprogram">Including - the results of a CGI program</a></li> - </ul> - </li> - - <li> - <a href="#additionalexamples">Additional examples</a> - - <ul> - <li><a href="#whenwasthisdocumentmodified">When was this - document modified?</a></li> - - <li><a href="#includingastandardfooter">Including a - standard footer</a></li> - - <li><a href="#whatelsecaniconfig">What else can I - config?</a></li> - - <li><a href="#executingcommands">Executing - commands</a></li> - </ul> - </li> - - <li> - <a href="#advancedssitechniques">Advanced SSI - techniques</a> - - <ul> - <li><a href="#settingvariables">Setting - variables</a></li> - - <li><a href="#conditionalexpressions">Conditional - expressions</a></li> - </ul> - </li> - - <li><a href="#conclusion">Conclusion</a></li> - </ul> - <!-- INDEX END --> - <hr /> - - <h2><a id="apachetutorial:introductiontoserversideincludes" - name="apachetutorial:introductiontoserversideincludes">Apache - Tutorial: Introduction to Server Side Includes</a></h2> - - <table border="1"> - <tr> - <td valign="top"><strong>Related Modules</strong><br /> - <br /> - <a href="../mod/mod_include.html">mod_include</a><br /> - <a href="../mod/mod_cgi.html">mod_cgi</a><br /> - <a href="../mod/mod_expires.html">mod_expires</a><br /> - </td> - - <td valign="top"><strong>Related Directives</strong><br /> - <br /> - <a href="../mod/core.html#options">Options</a><br /> - <a - href="../mod/mod_include.html#xbithack">XBitHack</a><br /> - <a href="../mod/mod_mime.html#addtype">AddType</a><br /> - <a - href="../mod/mod_mime.html#addhandler">AddHandler</a><br /> - <a - href="../mod/mod_setenvif.html#browsermatchnocase">BrowserMatchNoCase</a><br /> - </td> - </tr> - </table> - - <p>This article deals with Server Side Includes, usually called - simply SSI. In this article, I'll talk about configuring your - server to permit SSI, and introduce some basic SSI techniques - for adding dynamic content to your existing HTML pages.</p> - - <p>In the latter part of the article, we'll talk about some of - the somewhat more advanced things that can be done with SSI, - such as conditional statements in your SSI directives.</p> - <hr /> - - <h2><a id="whataressi" name="whataressi">What are SSI?</a></h2> - - <p>SSI (Server Side Includes) are directives that are placed in - HTML pages, and evaluated on the server while the pages are - being served. They let you add dynamically generated content to - an existing HTML page, without having to serve the entire page - via a CGI program, or other dynamic technology.</p> - - <p>The decision of when to use SSI, and when to have your page - entirely generated by some program, is usually a matter of how - much of the page is static, and how much needs to be - recalculated every time the page is served. SSI is a great way - to add small pieces of information, such as the current time. - But if a majority of your page is being generated at the time - that it is served, you need to look for some other - solution.</p> - <hr /> - - <h2><a id="configuringyourservertopermitssi" - name="configuringyourservertopermitssi">Configuring your server - to permit SSI</a></h2> - - <p>To permit SSI on your server, you must have <a - href="../mod/mod_include.html">mod_include</a> installed and - enabled. Additionally, you must have the following - directive either in your <code>httpd.conf</code> file, or in a - <code>.htaccess</code> file:</p> -<pre> - Options +Includes -</pre> - - <p>This tells Apache that you want to permit files to be parsed - for SSI directives. Note that most configurations contain - multiple <a href="../mod/core.html#options">Options</a> directives - that can override each other. You will probably need to apply the - <code>Options</code> to the specific directory where you want SSI - enabled in order to assure that it gets evaluated last.</p> - - <p>Not just any file is parsed for SSI directives. You have to - tell Apache which files should be parsed. There are two ways to - do this. You can tell Apache to parse any file with a - particular file extension, such as <code>.shtml</code>, with - the following directives:</p> -<pre> - AddType text/html .shtml - AddHandler server-parsed .shtml -</pre> - - <p>One disadvantage to this approach is that if you wanted to - add SSI directives to an existing page, you would have to - change the name of that page, and all links to that page, in - order to give it a <code>.shtml</code> extension, so that those - directives would be executed.</p> - - <p>The other method is to use the <code>XBitHack</code> - directive:</p> -<pre> - XBitHack on -</pre> - - <p><code>XBitHack</code> tells Apache to parse files for SSI - directives if they have the execute bit set. So, to add SSI - directives to an existing page, rather than having to change - the file name, you would just need to make the file executable - using <code>chmod</code>.</p> -<pre> - chmod +x pagename.html -</pre> - - <p>A brief comment about what not to do. You'll occasionally - see people recommending that you just tell Apache to parse all - <code>.html</code> files for SSI, so that you don't have to - mess with <code>.shtml</code> file names. These folks have - perhaps not heard about <code>XBitHack</code>. The thing to - keep in mind is that, by doing this, you're requiring that - Apache read through every single file that it sends out to - clients, even if they don't contain any SSI directives. This - can slow things down quite a bit, and is not a good idea.</p> - - <p>Of course, on Windows, there is no such thing as an execute - bit to set, so that limits your options a little.</p> - - <p>In its default configuration, Apache does not send the last - modified date or content length HTTP headers on SSI pages, - because these values are difficult to calculate for dynamic - content. This can prevent your document from being cached, and - result in slower perceived client performance. There are two - ways to solve this:</p> - - <ol> - <li>Use the <code>XBitHack Full</code> configuration. This - tells Apache to determine the last modified date by looking - only at the date of the originally requested file, ignoring - the modification date of any included files.</li> - - <li>Use the directives provided by <a - href="../mod/mod_expires.html">mod_expires</a> to set an - explicit expiration time on your files, thereby letting - browsers and proxies know that it is acceptable to cache - them.</li> - </ol> - <hr /> - - <h2><a id="basicssidirectives" name="basicssidirectives">Basic - SSI directives</a></h2> - - <p>SSI directives have the following syntax:</p> -<pre> - <!--#element attribute=value attribute=value ... --> -</pre> - - <p>It is formatted like an HTML comment, so if you don't have - SSI correctly enabled, the browser will ignore it, but it will - still be visible in the HTML source. If you have SSI correctly - configured, the directive will be replaced with its - results.</p> - - <p>The element can be one of a number of things, and we'll talk - some more about most of these in the next installment of this - series. For now, here are some examples of what you can do with - SSI</p> - - <h3><a id="today'sdate" name="today'sdate">Today's - date</a></h3> -<pre> - <!--#echo var="DATE_LOCAL" --> -</pre> - - <p>The <code>echo</code> element just spits out the value of a - variable. There are a number of standard variables, which - include the whole set of environment variables that are - available to CGI programs. Also, you can define your own - variables with the <code>set</code> element.</p> - - <p>If you don't like the format in which the date gets printed, - you can use the <code>config</code> element, with a - <code>timefmt</code> attribute, to modify that formatting.</p> -<pre> - <!--#config timefmt="%A %B %d, %Y" --> - Today is <!--#echo var="DATE_LOCAL" --> -</pre> - - <h3><a id="modificationdateofthefile" - name="modificationdateofthefile">Modification date of the - file</a></h3> -<pre> - This document last modified <!--#flastmod file="index.html" --> -</pre> - - <p>This element is also subject to <code>timefmt</code> format - configurations.</p> - - <h3><a id="includingtheresultsofacgiprogram" - name="includingtheresultsofacgiprogram">Including the results - of a CGI program</a></h3> - - <p>This is one of the more common uses of SSI - to output the - results of a CGI program, such as everybody's favorite, a ``hit - counter.''</p> -<pre> - <!--#include virtual="/cgi-bin/counter.pl" --> -</pre> - <hr /> - - <h2><a id="additionalexamples" - name="additionalexamples">Additional examples</a></h2> - - <p>Following are some specific examples of things you can do in - your HTML documents with SSI.</p> - <hr /> - - <h2><a id="whenwasthisdocumentmodified" - name="whenwasthisdocumentmodified">When was this document - modified?</a></h2> - - <p>Earlier, we mentioned that you could use SSI to inform the - user when the document was most recently modified. However, the - actual method for doing that was left somewhat in question. The - following code, placed in your HTML document, will put such a - time stamp on your page. Of course, you will have to have SSI - correctly enabled, as discussed above.</p> -<pre> - <!--#config timefmt="%A %B %d, %Y" --> - This file last modified <!--#flastmod file="ssi.shtml" --> -</pre> - - <p>Of course, you will need to replace the - <code>ssi.shtml</code> with the actual name of the file that - you're referring to. This can be inconvenient if you're just - looking for a generic piece of code that you can paste into any - file, so you probably want to use the - <code>LAST_MODIFIED</code> variable instead:</p> -<pre> - <!--#config timefmt="%D" --> - This file last modified <!--#echo var="LAST_MODIFIED" --> -</pre> - - <p>For more details on the <code>timefmt</code> format, go to - your favorite search site and look for <code>strftime()</code>. The - syntax is the same.</p> - <hr /> - - <h2><a id="includingastandardfooter" - name="includingastandardfooter">Including a standard - footer</a></h2> - - <p>If you are managing any site that is more than a few pages, - you may find that making changes to all those pages can be a - real pain, particularly if you are trying to maintain some kind - of standard look across all those pages.</p> - - <p>Using an include file for a header and/or a footer can - reduce the burden of these updates. You just have to make one - footer file, and then include it into each page with the - <code>include</code> SSI command. The <code>include</code> - element can determine what file to include with either the - <code>file</code> attribute, or the <code>virtual</code> - attribute. The <code>file</code> attribute is a file path, - <em>relative to the current directory</em>. That means that it - cannot be an absolute file path (starting with /), nor can it - contain ../ as part of that path. The <code>virtual</code> - attribute is probably more useful, and should specify a URL - relative to the document being served. It can start with a /, - but must be on the same server as the file being served.</p> -<pre> - <!--#include virtual="/footer.html" --> -</pre> - - <p>I'll frequently combine the last two things, putting a - <code>LAST_MODIFIED</code> directive inside a footer file to be - included. SSI directives can be contained in the included file, - and includes can be nested - that is, the included file can - include another file, and so on.</p> - <hr /> - - <h2><a id="whatelsecaniconfig" name="whatelsecaniconfig">What - else can I config?</a></h2> - - <p>In addition to being able to <code>config</code> the time - format, you can also <code>config</code> two other things.</p> - - <p>Usually, when something goes wrong with your SSI directive, - you get the message</p> -<pre> - [an error occurred while processing this directive] -</pre> - - <p>If you want to change that message to something else, you - can do so with the <code>errmsg</code> attribute to the - <code>config</code> element:</p> -<pre> - <!--#config errmsg="[It appears that you don't know how to use SSI]" --> -</pre> - - <p>Hopefully, end users will never see this message, because - you will have resolved all the problems with your SSI - directives before your site goes live. (Right?)</p> - - <p>And you can <code>config</code> the format in which file - sizes are returned with the <code>sizefmt</code> attribute. You - can specify <code>bytes</code> for a full count in bytes, or - <code>abbrev</code> for an abbreviated number in Kb or Mb, as - appropriate.</p> - <hr /> - - <h2><a id="executingcommands" - name="executingcommands">Executing commands</a></h2> - - <p>I expect that I'll have an article some time in the coming - months about using SSI with small CGI programs. For now, here's - something else that you can do with the <code>exec</code> - element. You can actually have SSI execute a command using the - shell (<code>/bin/sh</code>, to be precise - or the DOS shell, - if you're on Win32). The following, for example, will give you - a directory listing.</p> -<pre> - <pre> - <!--#exec cmd="ls" --> - </pre> -</pre> - - <p>or, on Windows</p> -<pre> - <pre> - <!--#exec cmd="dir" --> - </pre> -</pre> - - <p>You might notice some strange formatting with this directive - on Windows, because the output from <code>dir</code> contains - the string ``<<code>dir</code>>'' in it, which confuses - browsers.</p> - - <p>Note that this feature is exceedingly dangerous, as it will - execute whatever code happens to be embedded in the - <code>exec</code> tag. If you have any situation where users - can edit content on your web pages, such as with a - ``guestbook'', for example, make sure that you have this - feature disabled. You can allow SSI, but not the - <code>exec</code> feature, with the <code>IncludesNOEXEC</code> - argument to the <code>Options</code> directive.</p> - <hr /> - - <h2><a id="advancedssitechniques" - name="advancedssitechniques">Advanced SSI techniques</a></h2> - - <p>In addition to spitting out content, Apache SSI gives you - the option of setting variables, and using those variables in - comparisons and conditionals.</p> - - <h3><a id="caveat" name="caveat">Caveat</a></h3> - - <p>Most of the features discussed in this article are only - available to you if you are running Apache 1.2 or later. Of - course, if you are not running Apache 1.2 or later, you need to - upgrade immediately, if not sooner. Go on. Do it now. We'll - wait.</p> - <hr /> - - <h2><a id="settingvariables" name="settingvariables">Setting - variables</a></h2> - - <p>Using the <code>set</code> directive, you can set variables - for later use. We'll need this later in the discussion, so - we'll talk about it here. The syntax of this is as follows:</p> -<pre> - <!--#set var="name" value="Rich" --> -</pre> - - <p>In addition to merely setting values literally like that, - you can use any other variable, including, for example, - environment variables, or some of the variables we discussed in - the last article (like <code>LAST_MODIFIED</code>, for example) - to give values to your variables. You will specify that - something is a variable, rather than a literal string, by using - the dollar sign ($) before the name of the variable.</p> -<pre> - <!--#set var="modified" value="$LAST_MODIFIED" --> -</pre> - - <p>To put a literal dollar sign into the value of your - variable, you need to escape the dollar sign with a - backslash.</p> -<pre> - <!--#set var="cost" value="\$100" --> -</pre> - - <p>Finally, if you want to put a variable in the midst of a - longer string, and there's a chance that the name of the - variable will run up against some other characters, and thus be - confused with those characters, you can place the name of the - variable in braces, to remove this confusion. (It's hard to - come up with a really good example of this, but hopefully - you'll get the point.)</p> -<pre> - <!--#set var="date" value="${DATE_LOCAL}_${DATE_GMT}" --> -</pre> - <hr /> - - <h2><a id="conditionalexpressions" - name="conditionalexpressions">Conditional expressions</a></h2> - - <p>Now that we have variables, and are able to set and compare - their values, we can use them to express conditionals. This - lets SSI be a tiny programming language of sorts. - <code>mod_include</code> provides an <code>if</code>, - <code>elif</code>, <code>else</code>, <code>endif</code> - structure for building conditional statements. This allows you - to effectively generate multiple logical pages out of one - actual page.</p> - - <p>The structure of this conditional construct is:</p> -<pre> - <!--#if expr="test_condition" --> - <!--#elif expr="test_condition" --> - <!--#else --> - <!--#endif --> -</pre> - - <p>A <em>test_condition</em> can be any sort of logical - comparison - either comparing values to one another, or testing - the ``truth'' of a particular value. (A given string is true if - it is nonempty.) For a full list of the comparison operators - available to you, see the <code>mod_include</code> - documentation. Here are some examples of how one might use this - construct.</p> - - <p>In your configuration file, you could put the following - line:</p> -<pre> - BrowserMatchNoCase macintosh Mac - BrowserMatchNoCase MSIE InternetExplorer -</pre> - - <p>This will set environment variables ``Mac'' and - ``InternetExplorer'' to true, if the client is running Internet - Explorer on a Macintosh.</p> - - <p>Then, in your SSI-enabled document, you might do the - following:</p> -<pre> - <!--#if expr="${Mac} && ${InternetExplorer}" --> - Apologetic text goes here - <!--#else --> - Cool JavaScript code goes here - <!--#endif --> -</pre> - - <p>Not that I have anything against IE on Macs - I just - struggled for a few hours last week trying to get some - JavaScript working on IE on a Mac, when it was working - everywhere else. The above was the interim workaround.</p> - - <p>Any other variable (either ones that you define, or normal - environment variables) can be used in conditional statements. - With Apache's ability to set environment variables with the - <code>SetEnvIf</code> directives, and other related directives, - this functionality can let you do some pretty involved dynamic - stuff without ever resorting to CGI.</p> - <hr /> - - <h2><a id="conclusion" name="conclusion">Conclusion</a></h2> - - <p>SSI is certainly not a replacement for CGI, or other - technologies used for generating dynamic web pages. But it is a - great way to add small amounts of dynamic content to pages, - without doing a lot of extra work.</p> - </body> -</html> - diff --git a/usr.sbin/httpd/htdocs/manual/howto/ssi.html.ja.jis b/usr.sbin/httpd/htdocs/manual/howto/ssi.html.ja.jis deleted file mode 100644 index 3273f9a7630..00000000000 --- a/usr.sbin/httpd/htdocs/manual/howto/ssi.html.ja.jis +++ /dev/null @@ -1,554 +0,0 @@ -<?xml version="1.0" encoding="iso-2022-jp"?> -<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" - "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> -<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja"> - <head> - - <title>Apache $B%A%e!<%H%j%"%k(B: Server Side Includes $BF~Lg(B</title> - - </head> - <!-- English revision: 1.14 --> - <!-- Background white, links blue (unvisited), navy (visited), red (active) --> - - <body bgcolor="#ffffff" text="#000000" link="#0000ff" - vlink="#000080" alink="#ff0000"> - <div align="CENTER"> - <img src="../images/sub.gif" alt="[APACHE DOCUMENTATION]" /> - - <h3>Apache HTTP Server Version 1.3</h3> - </div> - - - - <h1 align="center">Apache $B%A%e!<%H%j%"%k(B: - Server Side Includes $BF~Lg(B</h1> - <a id="__index__" name="__index__"></a> <!-- INDEX BEGIN --> - - - <ul> - <li><a - href="#apachetutorial:introductiontoserversideincludes">Apache - $B%A%e!<%H%j%"%k(B: Server Side Includes $BF~Lg(B</a></li> - - <li><a href="#whataressi">SSI $B$H$O(B?</a></li> - - <li><a href="#configuringyourservertopermitssi">SSI - $B$r5v2D$9$k$?$a$N%5!<%P$N@_Dj(B</a></li> - - <li> - <a href="#basicssidirectives">$B4pK\E*$J(B SSI $B%G%#%l%/%F%#%V(B</a> - - <ul> - <li><a href="#today'sdate">$B:#F|$NF|IU(B</a></li> - - <li><a href="#modificationdateofthefile">$B%U%!%$%k$NJQ99F|(B</a></li> - - <li><a href="#includingtheresultsofacgiprogram">CGI - $B%W%m%0%i%`$N7k2L$r<h$j9~$`(B</a></li> - </ul> - </li> - - - <li> - <a href="#additionalexamples">$BDI2C$NNc(B</a> - - <ul> - <li><a href="#whenwasthisdocumentmodified" - >$B$$$D$3$N%I%-%e%a%s%H$O=$@5$5$l$?$N$+(B?</a></li> - - <li><a href="#includingastandardfooter" - >$BI8=`$N%U%C%?$rA^F~$9$k(B</a></li> - - <li><a href="#whatelsecaniconfig" - >$BB>$K2?$,@_Dj$G$-$k$N$+(B?</a></li> - - <li><a href="#executingcommands">$B%3%^%s%I$N<B9T(B</a> - </li> - </ul> - </li> - - <li> - <a href="#advancedssitechniques">$B9bEY$J(B SSI $B%F%/%K%C%/(B</a> - - - <ul> - <li><a href="#settingvariables">$BJQ?t$r@_Dj$9$k(B</a> - </li> - - <li><a href="#conditionalexpressions">$B>r7o<0(B</a></li> - </ul> - </li> - - - <li><a href="#conclusion">$B=*$o$j$K(B</a></li> - </ul> - <!-- INDEX END --> - <hr /> - - <h2><a id="apachetutorial:introductiontoserversideincludes" - name="apachetutorial:introductiontoserversideincludes">Apache - $B%A%e!<%H%j%"%k(B: Server Side Includes $BF~Lg(B</a></h2> - - <table border="1"> - <tr> - <td valign="top"><strong>$B4XO"%b%8%e!<%k(B</strong><br /> - <br /> - <a href="../mod/mod_include.html">mod_include</a><br /> - <a href="../mod/mod_cgi.html">mod_cgi</a><br /> - <a href="../mod/mod_expires.html">mod_expires</a><br /> - </td> - - <td valign="top"><strong>$B4XO"%G%#%l%/%F%#%V(B</strong><br /> - <br /> - <a href="../mod/core.html#options">Options</a><br /> - <a - href="../mod/mod_include.html#xbithack">XBitHack</a><br /> - <a href="../mod/mod_mime.html#addtype">AddType</a><br /> - <a - href="../mod/mod_mime.html#addhandler">AddHandler</a><br /> - <a href="../mod/mod_setenvif.html#browsermatchnocase" - >BrowserMatchNoCase</a><br /> - </td> - </tr> - </table> - - <p>$B$3$N5-;v$O!"DL>o$OC1$K(B SSI $B$H8F$P$l$k(B Server Side Includes - $B$r07$$$^$9!#$3$N5-;v$K$*$$$F$O!"%5!<%P$G$N(B SSI $B$r5v2D$9$k$?$a$N@_Dj$H!"(B - $B8=:_$N(B HTML $B%Z!<%8$KF0E*$J%3%s%F%s%D$r2C$($k$?$a$N$$$/$D$+$N4pK\E*$J(B - SSI $B5;=Q$r>R2p$7$^$9!#(B</p> - - <p>$B5-;v$N8eH>$G$O!"(BSSI $B%G%#%l%/%F%#%V$G(B SSI - $B$H6&$K<B9T$9$k$3$H$,$G$-$k>r7oJ8$N$h$&$J(B - $B4vJ,9bEY$J;vJA$K$D$$$F=R$Y$F$$$^$9!#(B</p> - <hr /> - - <h2><a id="whataressi" name="whataressi">SSI $B$H$O(B?</a></h2> - - <p>SSI (Server Side Includes) $B$O!"(BHTML - $B%Z!<%8Cf$KG[CV$5$l$k%G%#%l%/%F%#%V$G$"$j!"(B - $B%5!<%P$G%Z!<%8$rDs6!$9$k;~$KI>2A$5$l$^$9!#(BSSI $B$O!"(BCGI - $B%W%m%0%i%`$d$=$NB>$NF0E*$J5;=Q$GA4$F$N%Z!<%8$rDs6!$;$:$K!"(B - $BF0E*$K@8@.$5$l$?%3%s%F%s%D$r8=:_$N(B HTML $B%Z!<%8$K2C$($^$9!#(B</p> - - <p>$B$I$&$$$&>l9g$K(B SSI $B$r;H$$!"$I$&$$$&>l9g$K%W%m%0%i%`$G(B - $B%Z!<%8$r40A4$K@8@.$9$k$+$O!"%Z!<%8$N$&$A$I$NDxEY$,@EE*$G$"$j!"(B - $B%Z!<%8$,Ds6!$5$l$k$?$S$K:F7W;;$9$kI,MW$,$I$NDxEY$"$k$+$GDL>o$O7hDj$7$^$9!#(B - SSI $B$O8=:_;~9o$N$h$&$J>.$5$$>pJs$r2C$($k$K$O$&$C$F$D$1$NJ}K!$G$9!#(B - $B$7$+$7!"$=$N%Z!<%8$N$[$H$s$I$NItJ,$,Ds6!;~$K@8@.$5$l$k>l9g$O!"(B - $BB>$NJ}K!$rC5$9I,MW$,$"$j$^$9!#(B - </p> - <hr /> - - - <h2><a id="configuringyourservertopermitssi" - name="configuringyourservertopermitssi">SSI - $B$r5v2D$9$k$?$a$N%5!<%P$N@_Dj(B</a></h2> - - <p>$B%5!<%P$G(B SSI $B$r5v2D$9$k$K$O!"(B<a - href="../mod/mod_include.html">mod_include</a> - $B$r%$%s%9%H!<%k!"M-8z2=$9$kI,MW$,$"$j$^$9!#$5$i$K!"(B - <code>httpd.conf</code> $B%U%!%$%k$^$?$O(B <code>.htaccess</code> - $B%U%!%$%k$K<!$N%G%#%l%/%F%#%V$r;XDj$9$kI,MW$,$"$j$^$9(B:</p> -<pre> - Options +Includes -</pre> - - <p>$B$3$N;XDj$O!"%U%!%$%k$r(B SSI $B%G%#%l%/%F%#%V$G2r@O$5$;$k$3$H$r5v2D$9$k(B - $B$H$$$&$3$H$r(B Apache $B$KEA$($^$9!#(B - $B$[$H$s$I$N@_Dj$G$O$*8_$$$r>e=q$-$G$-$k!"J#?t$N(B - <a href="../mod/core.html#options">Options</a> $B$,$"$k$3$H$K(B - $BCm0U$7$F$/$@$5$$!#$*$=$i$/!"@_Dj$,:G8e$KI>2A$5$l$k$3$H$r(B - $BJ]>Z$5$l$k$?$a$K!"(BSSI $B$r;HMQ$7$?$$%G%#%l%/%H%j$K(B <code>Options</code> - $B%G%#%l%/%F%#%V$rE,MQ$9$kI,MW$,$"$k$G$7$g$&!#(B</p> - - <p>$BA4$F$N%U%!%$%k$,(B SSI $B%G%#%l%/%F%#%V$G2r@O$5$l$k$H$$$&$o$1$G$O$"$j$^$;$s!#(B - $B$I$N%U%!%$%k$,2r@O$5$l$k$+$r(B Apache $B$KEA$($kI,MW$,$"$j$^$9!#(B - $B$3$l$r9T$J$&$K$OFs$DJ}K!$,$"$j$^$9!#<!$N%G%#%l%/%F%#%V$r;H$&$3$H$G!"(B - $BNc$($P(B <code>.shtml</code> $B$N$h$&$JFCJL$J%U%!%$%k3HD%;R$r;}$D(B - $B%U%!%$%k$r2r@O$9$k$h$&(B Apache $B$KEA$($k$3$H$,$G$-$^$9(B:</p> -<pre> - AddType text/html .shtml - AddHandler server-parsed .shtml -</pre> - - <p>$B$3$NJ}K!$N7gE@$O!"$b$78=:_$N%Z!<%8$K(B SSI - $B%G%#%l%/%F%#%V$r2C$($?$$>l9g!"$=$l$i$N%G%#%l%/%F%#%V$,<B9T$5$l$k$h$&$K(B - <code>.shtml</code> $B3HD%;R$K$9$k$?$a!"$=$N%Z!<%8$NL>A0$H!"(B - $B$=$N%Z!<%8$X$NA4$F$N%j%s%/$rJQ99$7$J$1$l$P$J$i$J$$$3$H$G$9!#(B - </p> - - <p>$B$b$&0l$D$NJ}K!$O!"(B<code>XBitHack</code> - $B%G%#%l%/%F%#%V$r;HMQ$9$k$3$H$G$9(B:</p> -<pre> - XBitHack on -</pre> - - <p><code>XBitHack</code> $B$O!"%U%!%$%k$N<B9T%S%C%H$,N)$C$F$$$k>l9g!"(B - SSI $B%G%#%l%/%F%#%V$K$h$j2r@O$9$k$3$H$r(B Apache $B$KEA$($^$9!#(B - $B=>$C$F!"(BSSI $B%G%#%l%/%F%#%V$r8=:_$N%Z!<%8$K2C$($k$?$a$K$O!"(B - $B%U%!%$%kL>$rJQ99$7$J$/$F$b$h$/!"C1$K(B <code>chmod</code> - $B$r;HMQ$7$F%U%!%$%k$r<B9T2DG=$K$9$k$@$1$G:Q$_$^$9!#(B</p> -<pre> - chmod +x pagename.html -</pre> - - <p>$B9T$J$&$Y$-$G$O$J$$$3$H$K4X$9$kC;$$%3%a%s%H!#;~!9C/$+$,!"A4$F$N(B - <code>.html</code> $B%U%!%$%k$r(B SSI $B$G2r@O$9$k$h$&(B Apache $B$KEA$($l$P!"(B - $B$o$6$o$6(B <code>.shtml</code> $B$H$$$&%U%!%$%kL>$K$9$kI,MW$,$J$$$H$$$C$F(B - $BA&$a$k$N$r8+$k$3$H$G$7$g$&!#$3$&$$$&?M$?$A$O!"$*$=$i$/(B - <code>XBitHack</code> $B$K$D$$$FJ9$$$?$3$H$,$J$$$N$G$7$g$&!#(B - $B$3$NJ}K!$K$D$$$FCm0U$9$k$3$H$O!"$?$H$((B SSI - $B%G%#%l%/%F%#%V$rA4$/4^$^$J$$>l9g$G$b!"(BApache $B$,%/%i%$%"%s%H$K(B - $BAw$kA4$F$N%U%!%$%k$r:G8e$^$GFI$_9~$^$;$k$3$H$K$J$j$^$9!#(B - $B$3$NJ}K!$O$+$J$j=hM}$rCY$/$9$k$b$N$G$"$j!"NI$/$J$$%"%$%G%"$G$9!#(B</p> - - <p>$B$b$A$m$s!"(BWindows $B$G$O$=$N$h$&$J<B9T%S%C%H$r%;%C%H(B - $B$9$k$h$&$J$b$N$O$"$j$^$;$s$N$G%*%W%7%g%s$,>/$7@)8B$5$l$F$$$^$9!#(B</p> - - <p>$B%G%U%)%k%H$N@_Dj$G$O!"(BApache $B$O(B SSI $B%Z!<%8$K$D$$$F:G=*JQ99;~9o$d(B - $B%3%s%F%s%D$ND9$5$r(B HTTP $B%X%C%@$KAw$j$^$;$s!#(B - $BF0E*$J%3%s%F%s%D$G$"$k$?$a!"$=$l$i$NCM$r7W;;$9$k$N$,Fq$7$$$+$i$G$9!#(B - $B$3$N$?$a%I%-%e%a%s%H$,%-%c%C%7%e$5$l$J$/$J$j!"(B - $B7k2L$H$7$F%/%i%$%"%s%H$N@-G=$,CY$/$J$C$?$h$&$K46$8$5$;$k$3$H$K$J$j$^$9!#(B - $B$3$l$r2r7h$9$kJ}K!$,Fs$D$"$j$^$9(B:</p> - - <ol> - <li><code>XBitHack Full</code> $B@_Dj$r;HMQ$9$k!#(B - $B$3$N@_Dj$K$h$j!"$b$H$b$HMW5a$5$l$?%U%!%$%k$N;~9o$r;2>H$7!"(B - $BFI$_9~$^$l$k%U%!%$%k$NJQ99;~9o$rL5;k$7$F:G=*JQ99;~9o$r7hDj$9$k$h$&(B - Apache $B$KEA$($^$9!#(B</li> - - <li><a href="../mod/mod_expires.html">mod_expires</a> - $B$GDs6!$5$l$F$$$k%G%#%l%/%F%#%V$r;HMQ$7$F!"(B - $B%U%!%$%k$,L58z$K$J$k;~9o$rL@<($7$^$9!#$3$l$K$h$j!"(B - $B%V%i%&%6$H%W%m%-%7$K%-%c%C%7%e$,M-8z$G$"$k$3$H$rDLCN$7$^$9!#(B - </li> - </ol> - <hr /> - - <h2><a id="basicssidirectives" name="basicssidirectives">$B4pK\E*$J(B - SSI $B%G%#%l%/%F%#%V(B</a></h2> - - <p>SSI $B%G%#%l%/%F%#%V$O0J2<$NJ8K!$G5-=R$7$^$9(B:</p> -<pre> - <!--#element attribute=value attribute=value ... --> -</pre> - - <p>HTML $B$N%3%a%s%H$N$h$&$J=q<0$r$7$F$$$k$N$G!"$b$7(B SSI - $B$r@5$7$/F0:n2DG=$K$7$J$1$l$P!"%V%i%&%6$O$=$l$rL5;k$9$k$G$7$g$&!#(B - $B$7$+$7!"(BHTML $B%=!<%9Cf$G$O8+$($^$9!#$b$7(B SSI $B$r@5$7$/@_Dj$7$?$J$i!"(B - $B%G%#%l%/%F%#%V$O$=$N7k2L$HCV$-49$($i$l$^$9!#(B - </p> - - <p>element $B$O$?$/$5$s$"$k$b$N$+$i0l$D;XDj$9$k$3$H$,$G$-$^$9!#(B - $B;XDj$G$-$k$b$N$NBgB??t$K$D$$$F$O!"<!2s$b$&>/$7>\$7$/@bL@$7$^$9!#(B - $B$3$3$G$O!"(BSSI $B$G9T$J$&$3$H$,$G$-$kNc$r$$$/$D$+<($7$^$9!#(B - </p> - - <h3><a id="todaysdate" name="todaysdate">$B:#F|$NF|IU(B</a></h3> -<pre> - <!--#echo var="DATE_LOCAL" --> -</pre> - - - <p><code>echo</code> $BMWAG$OC1$KJQ?t$NCM$r=PNO$7$^$9!#(B - CGI $B%W%m%0%i%`$KMxMQ2DG=$J4D6-JQ?t$NA4$F$N(B - $B%;%C%H$r4^$`B?$/$NI8=`JQ?t$,$"$j$^$9!#$^$?!"(B<code>set</code> - $BMWAG$rMQ$$$k$3$H$G!"FH<+$NJQ?t$rDj5A$9$k$3$H$,$G$-$^$9!#(B - </p> - - <p>$B=PNO$5$l$kF|IU$N=q<0$,9%$-$G$O$J$$>l9g!"$=$N=q<0$r=$@5$9$k$?$a$K!"(B - <code>config</code> $BMWAG$K(B <code>timefmt</code> - $BB0@-$r;HMQ$9$k$3$H$,$G$-$^$9!#(B</p> -<pre> - <!--#config timefmt="%A %B %d, %Y" --> - Today is <!--#echo var="DATE_LOCAL" --> -</pre> - - <h3><a id="modificationdateofthefile" - name="modificationdateofthefile">$B%U%!%$%k$NJQ99F|(B</a></h3> -<pre> - This document last modified <!--#flastmod file="index.html" --> -</pre> - - - <p>$B$3$NMWAG$b(B <code>timefmt</code> - $B%U%)!<%^%C%H$N@_Dj$K=>$$$^$9!#(B</p> - - <h3><a name="includingtheresultsofacgiprogram" - id="includingtheresultsofacgiprogram">CGI - $B%W%m%0%i%`$N7k2L$r<h$j9~$`(B</a></h3> - - <p>$B$3$l$O!"A4$F$N?M$N$*5$$KF~$j$G$"$k(B ``$B%R%C%H%+%&%s%?(B'' $B$N$h$&$J(B - CGI $B%W%m%0%i%`$N7k2L$r=PNO$9$k(B SSI - $B$N$h$j0lHLE*$J;HMQ$N$&$A$N0l$D$G$9!#(B</p> -<pre> - <!--#include virtual="/cgi-bin/counter.pl" --> -</pre> - <hr /> - - <h2><a id="additionalexamples" - name="additionalexamples">$BDI2C$NNc(B</a></h2> - - <p>$B0J2<$O!"(BSSI $B$r;HMQ$7$F(B HTML - $B%I%-%e%a%s%H$K$*$$$F$G$-$k$3$H$N$$$/$D$+$NFCJL$JNc$G$9!#(B</p> - <hr /> - - <h2><a name="whenwasthisdocumentmodified" - id="whenwasthisdocumentmodified" - >$B$$$D$3$N%I%-%e%a%s%H$O=$@5$5$l$?$N$+(B?</a></h2> - - <p>$B@h$K!"%I%-%e%a%s%H$,:G8e$KJQ99$5$l$?$N$O$$$D$J$N$+$r(B - $B%f!<%6$KDLCN$9$k$?$a$K(B SSI $B$r;HMQ$9$k$3$H$,$G$-$k$3$H$r=R$Y$^$7$?!#(B - $B$7$+$7$J$,$i!"<B:]$NJ}K!$O!"$$$/$V$sLdBj$N$^$^$K$7$F$*$-$^$7$?!#(B - HTML $B%I%-%e%a%s%H$KG[CV$5$l$?<!$N%3!<%I$O!"%Z!<%8$K$=$N$h$&$J(B - $B%?%$%`%9%?%s%W$rF~$l$k$G$7$g$&!#$b$A$m$s!">e=R$N$h$&$K!"(B - SSI $B$r@5$7$/F0:n2DG=$K$7$F$*$/I,MW$,$"$j$^$9!#(B</p> -<pre> - <!--#config timefmt="%A %B %d, %Y" --> - This file last modified <!--#flastmod file="ssi.shtml" --> -</pre> - - <p>$B$b$A$m$s!"(B<code>ssi.shtml</code> - $B$NItJ,$r<B:]$NEv3:%U%!%$%kL>$HCV$-49$($kI,MW$,$"$j$^$9!#(B - $B$b$7!"$"$i$f$k%U%!%$%k$KD%$k$3$H$,$G$-$k0lHLE*$J%3!<%I$rC5$7$F$$$k$J$i!"(B - $B$3$l$OITJX$G$"$k$+$b$7$l$^$;$s!#$*$=$i$/$=$N>l9g$O!"(B - $B$=$&$9$kBe$o$j$KJQ?t(B <code>LAST_MODIFIED</code> - $B$r;HMQ$7$?$$$H9M$($k$G$7$g$&(B:</p> -<pre> - <!--#config timefmt="%D" --> - This file last modified <!--#echo var="LAST_MODIFIED" --> -</pre> - - <p><code>timefmt</code> - $B=q<0$K$D$$$F$N$h$j>\:Y$K$D$$$F$O!"$*9%$_$N8!:w%5%$%H$K9T$-!"(B - <code>strftime</code> $B$G8!:w$7$F$_$F$/$@$5$$!#J8K!$OF1$8$G$9!#(B</p> - <hr /> - - <h2><a id="includingastandardfooter" - name="includingastandardfooter">$BI8=`$N%U%C%?$rA^F~$9$k(B</a></h2> - - - <p>$B$b$7?t%Z!<%8$rD6$($k%Z!<%8$r;}$D%5%$%H$r4IM}$7$F$$$k$J$i$P!"(B - $BA4%Z!<%8$KBP$7$FJQ99$r9T$J$&$3$H$,K\Ev$K6lDK$H$J$jF@$k$3$H$,(B - $BJ,$+$k$G$7$g$&!#A4$F$N%Z!<%8$KEO$C$F$"$k<o$NI8=`E*$J304Q$r(B - $B0];}$7$h$&$H$7$F$$$k$J$i$PFC$K$=$&$G$7$g$&!#(B</p> - - <p>$B%X%C%@$d%U%C%?MQ$NA^F~MQ%U%!%$%k$r;HMQ$9$k$3$H$G!"(B - $B$3$N$h$&$J99?7$K$+$+$kIiC4$r8:$i$9$3$H$,$G$-$^$9!#(B - $B0l$D$N%U%C%?%U%!%$%k$r:n@.$7!"$=$l$r(B <code>include</code> - SSI $B%3%^%s%I$G3F%Z!<%8$KF~$l$k$@$1$G:Q$_$^$9!#(B<code>include</code> - $BMWAG$O!"(B<code>file</code> $BB0@-$^$?$O(B <code>virtual</code> - $BB0@-$N$$$:$l$+$r;HMQ$7$F$I$N%U%!%$%k$rA^F~$9$k$+$r7h$a$k$3$H$,$G$-$^$9!#(B - <code>file</code> $BB0@-$O!"(B - <em>$B%+%l%s%H%G%#%l%/%H%j$+$i$NAjBP%Q%9$G<($5$l$?(B</em>$B%U%!%$%k%Q%9$G$9!#(B - $B$=$l$O(B / $B$G;O$^$k@dBP%U%!%$%k%Q%9$K$O$G$-$:!"$^$?!"$=$N%Q%9$N0lIt$K(B ../ - $B$r4^$`$3$H$,$G$-$J$$$3$H$r0UL#$7$^$9!#(B<code>virtual</code> - $BB0@-$O!"$*$=$i$/$h$jJXMx$@$H;W$$$^$9$,!"Ds6!$9$k%I%-%e%a%s%H$+$i$NAjBP(B - URL $B$G;XDj$9$Y$-$G$9!#$=$l$O(B / $B$G;O$a$k$3$H$,$G$-$^$9$,!"(B - $BDs6!$9$k%U%!%$%k$HF1$8%5!<%P>e$KB8:_$7$J$/$F$O$J$j$^$;$s!#(B</p> -<pre> - <!--#include virtual="/footer.html" --> -</pre> - - <p>$B;d$O:G8e$NFs$D$rAH$_9g$o$;$F!"(B<code>LAST_MODIFIED</code> - $B%G%#%l%/%F%#%V$r%U%C%?%U%!%$%k$NCf$KCV$/$3$H$,$h$/$"$j$^$9!#(B - SSI $B%G%#%l%/%F%#%V$O!"A^F~MQ$N%U%!%$%k$K4^$^$;$?$j!"(B - $BA^F~%U%!%$%k$N%M%9%H$r$7$?$j$9$k$3$H$,$G$-$^$9!#$9$J$o$A!"(B - $BA^F~MQ$N%U%!%$%k$OB>$N%U%!%$%k$r:F5"E*$KA^F~$9$k$3$H$,$G$-$^$9!#(B</p> - <hr /> - - <h2><a name="whatelsecaniconfig" - id="whatelsecaniconfig">$BB>$K2?$,@_Dj$G$-$k$N$+(B?</a></h2> - - <p>$B;~9o=q<0$r(B <code>config</code> $B$G@_Dj$G$-$k$3$H$K2C$($F!"(B - $B99$KFs$D(B <code>config</code> $B$G@_Dj$9$k$3$H$,$G$-$^$9!#(B</p> - - <p>$BDL>o!"(BSSI $B%G%#%l%/%F%#%V$G2?$+$,$&$^$/$$$+$J$$$H$-$O!"(B - $B<!$N%a%C%;!<%8$,=PNO$5$l$^$9!#(B</p> -<pre> - [an error occurred while processing this directive] -</pre> - - <p>$B$3$N%a%C%;!<%8$rB>$N$b$N$K$7$?$$>l9g!"(B<code>config</code> - $BMWAG$N(B <code>errmsg</code> $BB0@-$GJQ99$9$k$3$H$,$G$-$^$9(B:</p> - -<pre> - <!--#config errmsg="[It appears that you don't know how to use SSI]" --> -</pre> - - <p>$B$*$=$i$/!"%(%s%I%f!<%6$O$3$N%a%C%;!<%8$r7h$7$F8+$k$3$H$O$"$j$^$;$s!#(B - $B$J$<$J$i!"$=$N%5%$%H$,@8$-$?>uBV$K$J$kA0$K(B SSI $B%G%#%l%/%F%#%V$K4X$9$k(B - $BA4$F$NLdBj$r2r7h$7$F$$$k$O$:$@$+$i$G$9!#(B($B$=$&$G$9$h$M(B?)</p> - - <p>$B$=$7$F!"(B<code>config</code> $B$K$*$$$F(B <code>sizefmt</code> - $BB0@-$r;HMQ$9$k$3$H$G!"(B - $BJV$5$l$k%U%!%$%k%5%$%:$N=q<0$r@_Dj$9$k$3$H$,$G$-$^$9!#(B - $B%P%$%H?t$K$O(B <code>bytes</code> $B$r!"E,Ev$K(B Kb $B$d(B Mb - $B$KC;=L$5$;$k$K$O(B <code>abbrev</code> $B$r;XDj$9$k$3$H$,$G$-$^$9!#(B</p> - <hr /> - - <h2><a id="executingcommands" - name="executingcommands">$B%3%^%s%I$N<B9T(B</a></h2> - - <p>$B:#8e?t%v7n$N$&$A$K!">.$5$J(B CGI $B%W%m%0%i%`$H(B SSI - $B$r;HMQ$9$k5-;v$r=P$7$?$$$H9M$($F$$$^$9!#$3$3$G$O$=$l$H$OJL$K!"(B - <code>exec</code> $BMWAG$K$h$C$F9T$J$&$3$H$,$G$-$k$3$H$r<($7$^$9!#(B - SSI $B$K%7%'%k(B ($B@53N$K$O(B <code>/bin/sh</code>$B!#(BWin32 $B$J$i$P(B DOS $B%7%'%k(B) - $B$r;HMQ$7$F%3%^%s%I$r<B9T$5$;$k$3$H$,$G$-$^$9!#(B - $B2<5-$NNc$G$O!"%G%#%l%/%H%j%j%9%H=PNO$r9T$J$$$^$9!#(B</p> - -<pre> - <pre> - <!--#exec cmd="ls" --> - </pre> -</pre> - - <p>Windows $B>e$G$O!"(B</p> -<pre> - <pre> - <!--#exec cmd="dir" --> - </pre> -</pre> - - <p>Windows $B>e$G$O!"$3$N%G%#%l%/%F%#%V$K$h$C$F$$$/$D$+$N4qL/$J(B - $B=q<0$K5$$E$/$G$7$g$&!#$J$<$J$i(B <code>dir</code> $B$N=PNO$,J8;zNs(B - ``<<code>dir</code>>'' $B$r4^$_!"%V%i%&%6$r:.Mp$5$;$k$+$i$G$9!#(B - </p> - - <p>$B$3$N5!G=$OHs>o$K4m81$G$"$j!"$I$s$J%3!<%I$G$b(B <code>exec</code> - $B%?%0$KKd$a9~$^$l$F$7$^$($P<B9T$9$k$3$H$KCm0U$7$F$/$@$5$$!#Nc$($P(B - `` $B%2%9%H%V%C%/(B '' $B$N$h$&$K!"$b$7!"(B - $B%f!<%6$,%Z!<%8$NFbMF$rJT=8$G$-$k>u67$K$"$k$J$i$P!"(B - $B$3$N5!G=$r3N<B$KM^@)$7$F$/$@$5$$!#(B<code>Options</code> - $B%G%#%l%/%F%#%V$N(B <code>IncludesNOEXEC</code> $B0z?t$r;XDj$9$k$3$H$G!"(B - SSI $B$O5v2D$9$k$1$l$I(B <code>exec</code> - $B5!G=$O5v2D$7$J$$$h$&$K$9$k$3$H$,$G$-$^$9!#(B</p> - <hr /> - - <h2><a id="advancedssitechniques" - name="advancedssitechniques">$B9bEY$J(B SSI $B%F%/%K%C%/(B</a></h2> - - <p>$B%3%s%F%s%D$r=PNO$9$k$3$H$K2C$(!"(BApache SSI $B$OJQ?t$r@_Dj$7!"(B - $B$=$7$FHf3S$H>r7oJ,4t$K$=$NJQ?t$r;HMQ$G$-$k5!G=$rDs6!$7$F$$$^$9!#(B - </p> - - <h3><a id="caveat" name="caveat">$B7Y9p(B</a></h3> - - <p>$B$3$N5-;v$G=R$Y$?BgItJ,$N5!G=$O!"(BApache 1.2 - $B0J9_$r;HMQ$7$F$$$k>l9g$N$_MxMQ2DG=$G$9!#EvA3$J$,$i!"$b$7(B Apache 1.2 - $B0J9_$r;HMQ$7$F$J$$>l9g!"D>$A$K%"%C%W%0%l!<%I$9$kI,MW$,$"$j$^$9!#(B - $B$5$!!":#$=$l$r9T$J$$$J$5$$!#$=$l$^$GBT$C$F$$$^$9!#(B - </p> - <hr /> - - <h2><a id="settingvariables" - name="settingvariables">$BJQ?t$r@_Dj$9$k(B</a></h2> - - <p><code>set</code> $B%G%#%l%/%F%#%V$r;HMQ$7$F!"(B - $B8e$G;HMQ$9$k$?$a$KJQ?t$r@_Dj$9$k$3$H$,$G$-$^$9!#(B - $B$3$l$O8e$N@bL@$GI,MW$K$J$k$N$G!"$3$3$G$=$l$K$D$$$F=R$Y$F$$$^$9!#(B - $BJ8K!$O0J2<$N$H$*$j$G$9(B:</p> -<pre> - <!--#set var="name" value="Rich" --> -</pre> - - <p>$B$3$N$h$&$KC1=c$KJ8;z$I$*$j$K@_Dj$9$k$3$H$K2C$(!"(B - $BNc$($P4D6-JQ?t$dA0$N5-;v$G=R$Y$?JQ?t(B - ($BNc$($P(B <code>LAST_MODIFIED</code>$B$N$h$&$J(B) - $B$r4^$`B>$N$"$i$f$kJQ?t$rCM$r@_Dj$9$k$N$K;HMQ$9$k$3$H$,$G$-$^$9!#(B - $BJQ?tL>$NA0$K%I%k5-9f(B ($) $B$r;HMQ$9$k$3$H$G!"(B - $B$=$l$,%j%F%i%kJ8;zNs$G$O$J$/$FJQ?t$G$"$k$3$H$r<($7$^$9!#(B</p> -<pre> - <!--#set var="modified" value="$LAST_MODIFIED" --> -</pre> - - <p>$B%I%k5-9f(B ($) $B$rJ8;z$H$7$FJQ?t$NCM$KF~$l$k$K$O!"(B - $B%P%C%/%9%i%C%7%e$K$h$C$F%I%k5-9f$r%(%9%1!<%W$9$kI,MW$,$"$j$^$9!#(B - </p> -<pre> - <!--#set var="cost" value="\$100" --> -</pre> - - <p>$B:G8e$K$J$j$^$9$,!"D9$$J8;zNs$NCf$KJQ?t$rCV$-$?$$>l9g$G!"(B - $BJQ?tL>$,B>$NJ8;z$H$V$D$+$k2DG=@-$,$"$j!"(B - $B$=$l$i$NJ8;z$K$D$$$F:.Mp$7$F$7$^$&>l9g!"$3$N:.Mp$r<h$j=|$/$?$a!"(B - $BJQ?tL>$rCf3g8L$G0O$`$3$H$,$G$-$^$9(B - ($B$3$l$K$D$$$F$NNI$$Nc$r<($9$N$OFq$7$$$N$G$9$,!"(B - $B$*$=$i$/J,$+$C$F$$$?$@$1$k$G$7$g$&(B)$B!#(B - </p> -<pre> - <!--#set var="date" value="${DATE_LOCAL}_${DATE_GMT}" --> -</pre> - <hr /> - - <h2><a id="conditionalexpressions" - name="conditionalexpressions">$B>r7o<0(B</a></h2> - - <p>$B$5$F!"JQ?t$r;}$C$F$$$F!"(B - $B$=$l$i$NCM$r@_Dj$7$FHf3S$9$k$3$H$,$G$-$k$N$G$9$+$i!"(B - $B>r7o$rI=$9$?$a$K$=$l$i$r;HMQ$9$k$3$H$,$G$-$^$9!#$3$l$K$h$j(B - SSI $B$O$"$k<o$N>.$5$J%W%m%0%i%_%s%08@8l$K$J$C$F$$$^$9!#(B - <code>mod_include</code> $B$O>r7o$rI=8=$9$k$?$a$K(B <code>if</code>, - <code>elif</code>, <code>else</code>, <code>endif</code> - $B9=B$$rDs6!$7$F$$$^$9!#$3$l$K$h$C$F!"(B - $B0l$D$N<B:]$N%Z!<%8$+$iJ#?t$NO@M}%Z!<%8$r8z2LE*$K@8@.$9$k$3$H$,$G$-$^$9!#(B</p> - - <p>$B>r7o9=B$$O0J2<$N$H$*$j$G$9(B:</p> -<pre> - <!--#if expr="test_condition" --> - <!--#elif expr="test_condition" --> - <!--#else --> - <!--#endif --> -</pre> - - <p><em>test_condition</em> - $B$O$"$i$f$k<oN`$NO@M}E*Hf3S$r$9$k$3$H$,$G$-$^$9!#(B - $BCM$rHf3S$7$?$j!"$=$NCM$,(B ``$B??(B'' $B$+$I$&$+$rI>2A$7$^$9(B - ($B6u$G$J$$$J$iM?$($i$l$?J8;zNs$O??$G$9(B)$B!#(B - $BMxMQ2DG=$JHf3S1i;;;R$NA4$F$N%j%9%H$K$D$$$F$O!"(B - <code>mod_include</code> $B%I%-%e%a%s%F!<%7%g%s$r;2>H$7$F$/$@$5$$!#(B - $B$3$3$G$O!"$3$N9=B$$r$I$&;HMQ$9$k$+$NNc$r$$$/$D$+<($7$^$9!#(B</p> - -<p>$B@_Dj%U%!%$%k$G<!$N9T$r5-=R$7$^$9(B:</p> - -<pre> - BrowserMatchNoCase macintosh Mac - BrowserMatchNoCase MSIE InternetExplorer -</pre> - - <p>$B$3$l$O%/%i%$%"%s%H$,(B Macintosh - $B>e$G%$%s%?!<%M%C%H%(%/%9%W%m!<%i$,F0$$$F$$$k>l9g!"4D6-JQ?t(B - ``Mac'' $B$H(B ``InternetExplorer'' $B$r??$H@_Dj$7$^$9!#(B</p> - - <p>$B<!$K!"(BSSI $B$,2DG=$K$J$C$?%I%-%e%a%s%H$G0J2<$r9T$J$$$^$9(B:</p> - -<pre> - <!--#if expr="${Mac} && ${InternetExplorer}" --> - Apologetic text goes here - <!--#else --> - Cool JavaScript code goes here - <!--#endif --> -</pre> - - <p>Mac $B>e$N(B IE $B$KBP$7$F2?$+;W$&$H$3$m$,$"$k$o$1$G$"$j$^$;$s!#(B - $BB>$G$O<B9T$G$-$F$$$k$$$/$D$+$N(B JavaScript $B$r(B Mac $B>e$N(B IE - $B$G<B9T$5$;$k$N$K!"@h=5?t;~4V6lO+$7$?$H$$$&$@$1$N$3$H$G$9!#(B - $B>e$NNc$O$=$N;CDjE*$JBP=hJ}K!$G$9!#(B</p> - - <p>$BB>$N$I$s$JJQ?t(B ($B$"$J$?$,Dj5A$9$k$b$N!"(B - $B$^$?$OIaDL$N4D6-JQ?t$N$$$:$l$+(B) $B$b!">r7oJ8$K;HMQ$9$k$3$H$,$G$-$^$9!#(B - Apache $B$O(B <code>SetEnvIf</code> $B%G%#%l%/%F%#%V$dB>$N4XO"(B - $B%G%#%l%/%F%#%V$r;HMQ$7$F4D6-JQ?t$r@_Dj$9$k$3$H$,$G$-$^$9!#(B - $B$3$N5!G=$K$h$j!"(BCGI - $B$KMj$k$3$H$J$/$+$J$jJ#;($JF0E*$J$3$H$r$5$;$k$3$H$,$G$-$^$9!#(B</p> - <hr /> - - <h2><a id="conclusion" name="conclusion">$B=*$o$j$K(B</a></h2> - - <p>SSI $B$O3N$+$K(B CGI - $B$dF0E*$J%&%'%V%Z!<%8$r@8@.$9$kB>$N5;=Q$KBe$o$k$b$N$G$O$"$j$^$;$s!#(B - $B$7$+$7!"$?$/$5$s$NM>J,$J:n6H$r$;$:$K!"(B - $B>/NL$NF0E*$J%3%s%F%s%D$r2C$($k$K$O$9$0$l$?J}K!$G$9!#(B</p> - </body> -</html> |