source: vendor/python/2.5/Doc/lib/libcgi.tex

Last change on this file was 3225, checked in by bird, 18 years ago

Python 2.5

File size: 23.8 KB
Line 
1\section{\module{cgi} ---
2 Common Gateway Interface support.}
3\declaremodule{standard}{cgi}
4
5\modulesynopsis{Common Gateway Interface support, used to interpret
6forms in server-side scripts.}
7
8\indexii{WWW}{server}
9\indexii{CGI}{protocol}
10\indexii{HTTP}{protocol}
11\indexii{MIME}{headers}
12\index{URL}
13
14
15Support module for Common Gateway Interface (CGI) scripts.%
16\index{Common Gateway Interface}
17
18This module defines a number of utilities for use by CGI scripts
19written in Python.
20
21\subsection{Introduction}
22\nodename{cgi-intro}
23
24A CGI script is invoked by an HTTP server, usually to process user
25input submitted through an HTML \code{<FORM>} or \code{<ISINDEX>} element.
26
27Most often, CGI scripts live in the server's special \file{cgi-bin}
28directory. The HTTP server places all sorts of information about the
29request (such as the client's hostname, the requested URL, the query
30string, and lots of other goodies) in the script's shell environment,
31executes the script, and sends the script's output back to the client.
32
33The script's input is connected to the client too, and sometimes the
34form data is read this way; at other times the form data is passed via
35the ``query string'' part of the URL. This module is intended
36to take care of the different cases and provide a simpler interface to
37the Python script. It also provides a number of utilities that help
38in debugging scripts, and the latest addition is support for file
39uploads from a form (if your browser supports it).
40
41The output of a CGI script should consist of two sections, separated
42by a blank line. The first section contains a number of headers,
43telling the client what kind of data is following. Python code to
44generate a minimal header section looks like this:
45
46\begin{verbatim}
47print "Content-Type: text/html" # HTML is following
48print # blank line, end of headers
49\end{verbatim}
50
51The second section is usually HTML, which allows the client software
52to display nicely formatted text with header, in-line images, etc.
53Here's Python code that prints a simple piece of HTML:
54
55\begin{verbatim}
56print "<TITLE>CGI script output</TITLE>"
57print "<H1>This is my first CGI script</H1>"
58print "Hello, world!"
59\end{verbatim}
60
61\subsection{Using the cgi module}
62\nodename{Using the cgi module}
63
64Begin by writing \samp{import cgi}. Do not use \samp{from cgi import
65*} --- the module defines all sorts of names for its own use or for
66backward compatibility that you don't want in your namespace.
67
68When you write a new script, consider adding the line:
69
70\begin{verbatim}
71import cgitb; cgitb.enable()
72\end{verbatim}
73
74This activates a special exception handler that will display detailed
75reports in the Web browser if any errors occur. If you'd rather not
76show the guts of your program to users of your script, you can have
77the reports saved to files instead, with a line like this:
78
79\begin{verbatim}
80import cgitb; cgitb.enable(display=0, logdir="/tmp")
81\end{verbatim}
82
83It's very helpful to use this feature during script development.
84The reports produced by \refmodule{cgitb} provide information that
85can save you a lot of time in tracking down bugs. You can always
86remove the \code{cgitb} line later when you have tested your script
87and are confident that it works correctly.
88
89To get at submitted form data,
90it's best to use the \class{FieldStorage} class. The other classes
91defined in this module are provided mostly for backward compatibility.
92Instantiate it exactly once, without arguments. This reads the form
93contents from standard input or the environment (depending on the
94value of various environment variables set according to the CGI
95standard). Since it may consume standard input, it should be
96instantiated only once.
97
98The \class{FieldStorage} instance can be indexed like a Python
99dictionary, and also supports the standard dictionary methods
100\method{has_key()} and \method{keys()}. The built-in \function{len()}
101is also supported. Form fields containing empty strings are ignored
102and do not appear in the dictionary; to keep such values, provide
103a true value for the optional \var{keep_blank_values} keyword
104parameter when creating the \class{FieldStorage} instance.
105
106For instance, the following code (which assumes that the
107\mailheader{Content-Type} header and blank line have already been
108printed) checks that the fields \code{name} and \code{addr} are both
109set to a non-empty string:
110
111\begin{verbatim}
112form = cgi.FieldStorage()
113if not (form.has_key("name") and form.has_key("addr")):
114 print "<H1>Error</H1>"
115 print "Please fill in the name and addr fields."
116 return
117print "<p>name:", form["name"].value
118print "<p>addr:", form["addr"].value
119...further form processing here...
120\end{verbatim}
121
122Here the fields, accessed through \samp{form[\var{key}]}, are
123themselves instances of \class{FieldStorage} (or
124\class{MiniFieldStorage}, depending on the form encoding).
125The \member{value} attribute of the instance yields the string value
126of the field. The \method{getvalue()} method returns this string value
127directly; it also accepts an optional second argument as a default to
128return if the requested key is not present.
129
130If the submitted form data contains more than one field with the same
131name, the object retrieved by \samp{form[\var{key}]} is not a
132\class{FieldStorage} or \class{MiniFieldStorage}
133instance but a list of such instances. Similarly, in this situation,
134\samp{form.getvalue(\var{key})} would return a list of strings.
135If you expect this possibility
136(when your HTML form contains multiple fields with the same name), use
137the \function{getlist()} function, which always returns a list of values (so that you
138do not need to special-case the single item case). For example, this
139code concatenates any number of username fields, separated by
140commas:
141
142\begin{verbatim}
143value = form.getlist("username")
144usernames = ",".join(value)
145\end{verbatim}
146
147If a field represents an uploaded file, accessing the value via the
148\member{value} attribute or the \function{getvalue()} method reads the
149entire file in memory as a string. This may not be what you want.
150You can test for an uploaded file by testing either the \member{filename}
151attribute or the \member{file} attribute. You can then read the data at
152leisure from the \member{file} attribute:
153
154\begin{verbatim}
155fileitem = form["userfile"]
156if fileitem.file:
157 # It's an uploaded file; count lines
158 linecount = 0
159 while 1:
160 line = fileitem.file.readline()
161 if not line: break
162 linecount = linecount + 1
163\end{verbatim}
164
165The file upload draft standard entertains the possibility of uploading
166multiple files from one field (using a recursive
167\mimetype{multipart/*} encoding). When this occurs, the item will be
168a dictionary-like \class{FieldStorage} item. This can be determined
169by testing its \member{type} attribute, which should be
170\mimetype{multipart/form-data} (or perhaps another MIME type matching
171\mimetype{multipart/*}). In this case, it can be iterated over
172recursively just like the top-level form object.
173
174When a form is submitted in the ``old'' format (as the query string or
175as a single data part of type
176\mimetype{application/x-www-form-urlencoded}), the items will actually
177be instances of the class \class{MiniFieldStorage}. In this case, the
178\member{list}, \member{file}, and \member{filename} attributes are
179always \code{None}.
180
181
182\subsection{Higher Level Interface}
183
184\versionadded{2.2} % XXX: Is this true ?
185
186The previous section explains how to read CGI form data using the
187\class{FieldStorage} class. This section describes a higher level
188interface which was added to this class to allow one to do it in a
189more readable and intuitive way. The interface doesn't make the
190techniques described in previous sections obsolete --- they are still
191useful to process file uploads efficiently, for example.
192
193The interface consists of two simple methods. Using the methods
194you can process form data in a generic way, without the need to worry
195whether only one or more values were posted under one name.
196
197In the previous section, you learned to write following code anytime
198you expected a user to post more than one value under one name:
199
200\begin{verbatim}
201item = form.getvalue("item")
202if isinstance(item, list):
203 # The user is requesting more than one item.
204else:
205 # The user is requesting only one item.
206\end{verbatim}
207
208This situation is common for example when a form contains a group of
209multiple checkboxes with the same name:
210
211\begin{verbatim}
212<input type="checkbox" name="item" value="1" />
213<input type="checkbox" name="item" value="2" />
214\end{verbatim}
215
216In most situations, however, there's only one form control with a
217particular name in a form and then you expect and need only one value
218associated with this name. So you write a script containing for
219example this code:
220
221\begin{verbatim}
222user = form.getvalue("user").upper()
223\end{verbatim}
224
225The problem with the code is that you should never expect that a
226client will provide valid input to your scripts. For example, if a
227curious user appends another \samp{user=foo} pair to the query string,
228then the script would crash, because in this situation the
229\code{getvalue("user")} method call returns a list instead of a
230string. Calling the \method{toupper()} method on a list is not valid
231(since lists do not have a method of this name) and results in an
232\exception{AttributeError} exception.
233
234Therefore, the appropriate way to read form data values was to always
235use the code which checks whether the obtained value is a single value
236or a list of values. That's annoying and leads to less readable
237scripts.
238
239A more convenient approach is to use the methods \method{getfirst()}
240and \method{getlist()} provided by this higher level interface.
241
242\begin{methoddesc}[FieldStorage]{getfirst}{name\optional{, default}}
243 This method always returns only one value associated with form field
244 \var{name}. The method returns only the first value in case that
245 more values were posted under such name. Please note that the order
246 in which the values are received may vary from browser to browser
247 and should not be counted on.\footnote{Note that some recent
248 versions of the HTML specification do state what order the
249 field values should be supplied in, but knowing whether a
250 request was received from a conforming browser, or even from a
251 browser at all, is tedious and error-prone.} If no such form
252 field or value exists then the method returns the value specified by
253 the optional parameter \var{default}. This parameter defaults to
254 \code{None} if not specified.
255\end{methoddesc}
256
257\begin{methoddesc}[FieldStorage]{getlist}{name}
258 This method always returns a list of values associated with form
259 field \var{name}. The method returns an empty list if no such form
260 field or value exists for \var{name}. It returns a list consisting
261 of one item if only one such value exists.
262\end{methoddesc}
263
264Using these methods you can write nice compact code:
265
266\begin{verbatim}
267import cgi
268form = cgi.FieldStorage()
269user = form.getfirst("user", "").upper() # This way it's safe.
270for item in form.getlist("item"):
271 do_something(item)
272\end{verbatim}
273
274
275\subsection{Old classes}
276
277These classes, present in earlier versions of the \module{cgi} module,
278are still supported for backward compatibility. New applications
279should use the \class{FieldStorage} class.
280
281\class{SvFormContentDict} stores single value form content as
282dictionary; it assumes each field name occurs in the form only once.
283
284\class{FormContentDict} stores multiple value form content as a
285dictionary (the form items are lists of values). Useful if your form
286contains multiple fields with the same name.
287
288Other classes (\class{FormContent}, \class{InterpFormContentDict}) are
289present for backwards compatibility with really old applications only.
290If you still use these and would be inconvenienced when they
291disappeared from a next version of this module, drop me a note.
292
293
294\subsection{Functions}
295\nodename{Functions in cgi module}
296
297These are useful if you want more control, or if you want to employ
298some of the algorithms implemented in this module in other
299circumstances.
300
301\begin{funcdesc}{parse}{fp\optional{, keep_blank_values\optional{,
302 strict_parsing}}}
303 Parse a query in the environment or from a file (the file defaults
304 to \code{sys.stdin}). The \var{keep_blank_values} and
305 \var{strict_parsing} parameters are passed to \function{parse_qs()}
306 unchanged.
307\end{funcdesc}
308
309\begin{funcdesc}{parse_qs}{qs\optional{, keep_blank_values\optional{,
310 strict_parsing}}}
311Parse a query string given as a string argument (data of type
312\mimetype{application/x-www-form-urlencoded}). Data are
313returned as a dictionary. The dictionary keys are the unique query
314variable names and the values are lists of values for each name.
315
316The optional argument \var{keep_blank_values} is
317a flag indicating whether blank values in
318URL encoded queries should be treated as blank strings.
319A true value indicates that blanks should be retained as
320blank strings. The default false value indicates that
321blank values are to be ignored and treated as if they were
322not included.
323
324The optional argument \var{strict_parsing} is a flag indicating what
325to do with parsing errors. If false (the default), errors
326are silently ignored. If true, errors raise a \exception{ValueError}
327exception.
328
329Use the \function{\refmodule{urllib}.urlencode()} function to convert
330such dictionaries into query strings.
331
332\end{funcdesc}
333
334\begin{funcdesc}{parse_qsl}{qs\optional{, keep_blank_values\optional{,
335 strict_parsing}}}
336Parse a query string given as a string argument (data of type
337\mimetype{application/x-www-form-urlencoded}). Data are
338returned as a list of name, value pairs.
339
340The optional argument \var{keep_blank_values} is
341a flag indicating whether blank values in
342URL encoded queries should be treated as blank strings.
343A true value indicates that blanks should be retained as
344blank strings. The default false value indicates that
345blank values are to be ignored and treated as if they were
346not included.
347
348The optional argument \var{strict_parsing} is a flag indicating what
349to do with parsing errors. If false (the default), errors
350are silently ignored. If true, errors raise a \exception{ValueError}
351exception.
352
353Use the \function{\refmodule{urllib}.urlencode()} function to convert
354such lists of pairs into query strings.
355\end{funcdesc}
356
357\begin{funcdesc}{parse_multipart}{fp, pdict}
358Parse input of type \mimetype{multipart/form-data} (for
359file uploads). Arguments are \var{fp} for the input file and
360\var{pdict} for a dictionary containing other parameters in
361the \mailheader{Content-Type} header.
362
363Returns a dictionary just like \function{parse_qs()} keys are the
364field names, each value is a list of values for that field. This is
365easy to use but not much good if you are expecting megabytes to be
366uploaded --- in that case, use the \class{FieldStorage} class instead
367which is much more flexible.
368
369Note that this does not parse nested multipart parts --- use
370\class{FieldStorage} for that.
371\end{funcdesc}
372
373\begin{funcdesc}{parse_header}{string}
374Parse a MIME header (such as \mailheader{Content-Type}) into a main
375value and a dictionary of parameters.
376\end{funcdesc}
377
378\begin{funcdesc}{test}{}
379Robust test CGI script, usable as main program.
380Writes minimal HTTP headers and formats all information provided to
381the script in HTML form.
382\end{funcdesc}
383
384\begin{funcdesc}{print_environ}{}
385Format the shell environment in HTML.
386\end{funcdesc}
387
388\begin{funcdesc}{print_form}{form}
389Format a form in HTML.
390\end{funcdesc}
391
392\begin{funcdesc}{print_directory}{}
393Format the current directory in HTML.
394\end{funcdesc}
395
396\begin{funcdesc}{print_environ_usage}{}
397Print a list of useful (used by CGI) environment variables in
398HTML.
399\end{funcdesc}
400
401\begin{funcdesc}{escape}{s\optional{, quote}}
402Convert the characters
403\character{\&}, \character{<} and \character{>} in string \var{s} to
404HTML-safe sequences. Use this if you need to display text that might
405contain such characters in HTML. If the optional flag \var{quote} is
406true, the quotation mark character (\character{"}) is also translated;
407this helps for inclusion in an HTML attribute value, as in \code{<A
408HREF="...">}. If the value to be quoted might include single- or
409double-quote characters, or both, consider using the
410\function{quoteattr()} function in the \refmodule{xml.sax.saxutils}
411module instead.
412\end{funcdesc}
413
414
415\subsection{Caring about security \label{cgi-security}}
416
417\indexii{CGI}{security}
418
419There's one important rule: if you invoke an external program (via the
420\function{os.system()} or \function{os.popen()} functions. or others
421with similar functionality), make very sure you don't pass arbitrary
422strings received from the client to the shell. This is a well-known
423security hole whereby clever hackers anywhere on the Web can exploit a
424gullible CGI script to invoke arbitrary shell commands. Even parts of
425the URL or field names cannot be trusted, since the request doesn't
426have to come from your form!
427
428To be on the safe side, if you must pass a string gotten from a form
429to a shell command, you should make sure the string contains only
430alphanumeric characters, dashes, underscores, and periods.
431
432
433\subsection{Installing your CGI script on a \UNIX\ system}
434
435Read the documentation for your HTTP server and check with your local
436system administrator to find the directory where CGI scripts should be
437installed; usually this is in a directory \file{cgi-bin} in the server tree.
438
439Make sure that your script is readable and executable by ``others''; the
440\UNIX{} file mode should be \code{0755} octal (use \samp{chmod 0755
441\var{filename}}). Make sure that the first line of the script contains
442\code{\#!} starting in column 1 followed by the pathname of the Python
443interpreter, for instance:
444
445\begin{verbatim}
446#!/usr/local/bin/python
447\end{verbatim}
448
449Make sure the Python interpreter exists and is executable by ``others''.
450
451Make sure that any files your script needs to read or write are
452readable or writable, respectively, by ``others'' --- their mode
453should be \code{0644} for readable and \code{0666} for writable. This
454is because, for security reasons, the HTTP server executes your script
455as user ``nobody'', without any special privileges. It can only read
456(write, execute) files that everybody can read (write, execute). The
457current directory at execution time is also different (it is usually
458the server's cgi-bin directory) and the set of environment variables
459is also different from what you get when you log in. In particular, don't
460count on the shell's search path for executables (\envvar{PATH}) or
461the Python module search path (\envvar{PYTHONPATH}) to be set to
462anything interesting.
463
464If you need to load modules from a directory which is not on Python's
465default module search path, you can change the path in your script,
466before importing other modules. For example:
467
468\begin{verbatim}
469import sys
470sys.path.insert(0, "/usr/home/joe/lib/python")
471sys.path.insert(0, "/usr/local/lib/python")
472\end{verbatim}
473
474(This way, the directory inserted last will be searched first!)
475
476Instructions for non-\UNIX{} systems will vary; check your HTTP server's
477documentation (it will usually have a section on CGI scripts).
478
479
480\subsection{Testing your CGI script}
481
482Unfortunately, a CGI script will generally not run when you try it
483from the command line, and a script that works perfectly from the
484command line may fail mysteriously when run from the server. There's
485one reason why you should still test your script from the command
486line: if it contains a syntax error, the Python interpreter won't
487execute it at all, and the HTTP server will most likely send a cryptic
488error to the client.
489
490Assuming your script has no syntax errors, yet it does not work, you
491have no choice but to read the next section.
492
493
494\subsection{Debugging CGI scripts} \indexii{CGI}{debugging}
495
496First of all, check for trivial installation errors --- reading the
497section above on installing your CGI script carefully can save you a
498lot of time. If you wonder whether you have understood the
499installation procedure correctly, try installing a copy of this module
500file (\file{cgi.py}) as a CGI script. When invoked as a script, the file
501will dump its environment and the contents of the form in HTML form.
502Give it the right mode etc, and send it a request. If it's installed
503in the standard \file{cgi-bin} directory, it should be possible to send it a
504request by entering a URL into your browser of the form:
505
506\begin{verbatim}
507http://yourhostname/cgi-bin/cgi.py?name=Joe+Blow&addr=At+Home
508\end{verbatim}
509
510If this gives an error of type 404, the server cannot find the script
511-- perhaps you need to install it in a different directory. If it
512gives another error, there's an installation problem that
513you should fix before trying to go any further. If you get a nicely
514formatted listing of the environment and form content (in this
515example, the fields should be listed as ``addr'' with value ``At Home''
516and ``name'' with value ``Joe Blow''), the \file{cgi.py} script has been
517installed correctly. If you follow the same procedure for your own
518script, you should now be able to debug it.
519
520The next step could be to call the \module{cgi} module's
521\function{test()} function from your script: replace its main code
522with the single statement
523
524\begin{verbatim}
525cgi.test()
526\end{verbatim}
527
528This should produce the same results as those gotten from installing
529the \file{cgi.py} file itself.
530
531When an ordinary Python script raises an unhandled exception (for
532whatever reason: of a typo in a module name, a file that can't be
533opened, etc.), the Python interpreter prints a nice traceback and
534exits. While the Python interpreter will still do this when your CGI
535script raises an exception, most likely the traceback will end up in
536one of the HTTP server's log files, or be discarded altogether.
537
538Fortunately, once you have managed to get your script to execute
539\emph{some} code, you can easily send tracebacks to the Web browser
540using the \refmodule{cgitb} module. If you haven't done so already,
541just add the line:
542
543\begin{verbatim}
544import cgitb; cgitb.enable()
545\end{verbatim}
546
547to the top of your script. Then try running it again; when a
548problem occurs, you should see a detailed report that will
549likely make apparent the cause of the crash.
550
551If you suspect that there may be a problem in importing the
552\refmodule{cgitb} module, you can use an even more robust approach
553(which only uses built-in modules):
554
555\begin{verbatim}
556import sys
557sys.stderr = sys.stdout
558print "Content-Type: text/plain"
559print
560...your code here...
561\end{verbatim}
562
563This relies on the Python interpreter to print the traceback. The
564content type of the output is set to plain text, which disables all
565HTML processing. If your script works, the raw HTML will be displayed
566by your client. If it raises an exception, most likely after the
567first two lines have been printed, a traceback will be displayed.
568Because no HTML interpretation is going on, the traceback will be
569readable.
570
571
572\subsection{Common problems and solutions}
573
574\begin{itemize}
575\item Most HTTP servers buffer the output from CGI scripts until the
576script is completed. This means that it is not possible to display a
577progress report on the client's display while the script is running.
578
579\item Check the installation instructions above.
580
581\item Check the HTTP server's log files. (\samp{tail -f logfile} in a
582separate window may be useful!)
583
584\item Always check a script for syntax errors first, by doing something
585like \samp{python script.py}.
586
587\item If your script does not have any syntax errors, try adding
588\samp{import cgitb; cgitb.enable()} to the top of the script.
589
590\item When invoking external programs, make sure they can be found.
591Usually, this means using absolute path names --- \envvar{PATH} is
592usually not set to a very useful value in a CGI script.
593
594\item When reading or writing external files, make sure they can be read
595or written by the userid under which your CGI script will be running:
596this is typically the userid under which the web server is running, or some
597explicitly specified userid for a web server's \samp{suexec} feature.
598
599\item Don't try to give a CGI script a set-uid mode. This doesn't work on
600most systems, and is a security liability as well.
601\end{itemize}
602
Note: See TracBrowser for help on using the repository browser.