问题是在HTTP中,头必须以空行结尾。因此,不是发送一个标题行和一个3行正文,而是发送四个标题行,其中除了一个是无意义的,然后在没有完成标题的情况下退出。在
因此,服务器抱怨脚本没有完成响应的编写就退出了。在
试试这个:print "Content-type:text/html"
print ""
print "
DATABASE
"print ""
如果您想记录每一行代码,正如您在注释中所说的,有两种方法可以做到这一点。在
快速而肮脏的方法是打开一个文件并write进入其中。例如:
^{pr2}$
更简单的方法是使用Python附带的^{}模块:#!/usr/bin/python
import cgitb
import MySQLdb
import cgi
import logging
logging.info('About to enable cgitb')
cgitb.enable()
logging.info('About to create FieldStorage')
form = cgi.FieldStorage()
这更简单(不需要在末尾添加\n,记录器可以为您格式化字符串,这样您就不必手动使用.format或{}等进行格式化)。而且它更加灵活(您可以在不同的级别记录不同的消息,您可以配置日志的位置—例如,将它们发送到您的system log而不是/tmp中的一个文件,等等)。而且它更健壮(不必担心忘记close文件并丢失最后的日志消息注意,在非logging示例中,我使用了with语句来获得相同的效果,但这需要缩进整个程序)。在
如果您有时间完成Logging Tutorial,您应该这样做。在
最后,如果您非常确定某行正在引发异常,但在服务器日志中的任何位置都找不到异常信息,下面是如何记录异常的方法:import traceback
try:
the line that raises
except Exception:
traceback.print_exc(None, logfile)
raise
这将捕获异常,并打印出与您在控制台解释器会话中获得的完全相同的详细回溯,但会将其打印到您先前打开的日志文件中,而不是控制台中,然后让异常正常传播。在
如果您使用的是logging模块,您可以使用它自己的内置异常日志记录,或者如果您想定制一些东西,您可以使用sys.exc_info和{}来获取要记录的字符串(或一系列字符串)。在