20.3. cgitb
— 用于 CGI 脚本的回溯管理器¶
2.2 新版功能.
cgitb
模块提供了用于 Python 脚本的特殊异常处理程序。 (这个名称有一点误导性。 它最初是设计用来显示 HTML 格式的 CGI 脚本详细回溯信息。 但后来被一般化为也可显示纯文本格式的回溯信息。) 激活这个模块之后,如果发生了未被捕获的异常,将会显示详细的已格式化的报告。 报告显示内容包括每个层级的源代码摘录,还有当前正在运行的函数的参数和局部变量值,以帮助你调试问题。 你也可以选择将此信息保存至文件而不是将其发送至浏览器。
要启用此特性,只需简单地将此代码添加到你的 CGI 脚本的最顶端:
import cgitb
cgitb.enable()
enable()
函数的选项可以控制是将报告显示在浏览器中,还是将报告记录到文件以供随后进行分析。
-
cgitb.
enable
([display[, logdir[, context[, format]]]])¶ 此函数可通过设置
sys.excepthook
的值以使cgitb
模块接管解释器默认的异常处理机制。可选参数 display 默认为
1
并可被设为0
来停止将回溯发送至浏览器。 如果给出了参数 logdir,则回溯会被写入文件。 logdir 的值应当是一个用于存放所写入文件的目录。 可选参数 context 是要在回溯中的当前源代码行前后显示的上下文行数;默认为5
。 如果可选参数 format 为"html"
,输出将为 HTML 格式。 任何其它值都会强制启用纯文本输出。 默认取值为"html"
。
-
cgitb.
handler
([info])¶ 此函数使用默认设置处理异常(即在浏览器中显示报告,但不记录到文件)。 当你捕获了一个异常并希望使用
cgitb
来报告它时可以使用此函数。 可选的 info 参数应为一个包含异常类型,异常值和回溯对象的 3 元组,与sys.exc_info()
所返回的元组完全一致。 如果未提供 info 参数,则会从sys.exc_info()
获取当前异常。