web.py 0.3 新手指南 - 安装
在某些版本的lighttpd中, 需要保证fastcgi.server选项下的"check-local"属性设置为"false", 特别是当你的?code.py不在文档根目录下。
如果你得到错误显示不能够导入flup, 请在命令行下输入 "easy_install flup" 来安装。
从修订版本 145开始, 如果你的代码使用了重定向,还需要在fastcgi选项下设置bin-environment变量。 如果你的代码重定向到http://domain.com/ 而在url栏中你会看到 http://domain.com/code.py/, 你可以通过设置这个环境变量来阻止。 这样你的fastcgi.server设置将会如下:
fastcgi.server = ( "/code.py" =>(( "socket" => "/tmp/fastcgi.socket", "bin-path" => "/path/to/root/code.py", "max-procs" => 1, "bin-environment" => ( "REAL_SCRIPT_NAME" => "" ), "check-local" => "disable")))添加以下到?httpd.conf?或?apache2.conf。
Alias /foo/static/ /path/to/staticScriptAlias /foo/ /path/to/code.pyCGI很容易配置, 但不适合高性能网站。 添加以下到你的?.htaccess:
Options +ExecCGIAddHandler cgi-script .py将你的浏览器指向?http://example.com/code.py/。 不要忘记最后的斜杠,否则你将会看到?not found?消息 (因为在?urls?列表中你输入的没有被匹配到). 为了让其运行的时候不需要添加?code.py, 启用mod_rewrite 法则 (查看如下)。
注意:?web.py?的实现破坏了?cgitb?模块,因为它截取了?stdout。 可以通过以下的方法来解决该问题:
import cgitb; cgitb.enable()import sys# ... import web etc here...def cgidebugerror(): """ """ _wrappedstdout = sys.stdout sys.stdout = web._oldstdout cgitb.handler() sys.stdout = _wrappedstdoutweb.internalerror = cgidebugerrorFastCGI很容易配置,运行方式如同mod_python。
添加以下到?.htaccess:
<Files code.py> SetHandler fastcgi-script</Files>不幸的是, 不像lighttpd, Apache不能够暗示你的web.py脚本以FastCGI 服务器的形式工作,因此你需要明确的告诉web.py。 添加以下到?code.py的?if __name__ == "__main__":?行前:
web.wsgi.runwsgi = lambda func, addr=None: web.wsgi.runfcgi(func, addr)将你的浏览器指向?http://example.com/code.py/。 不要忘记最后的斜杠,否则你将会看到?not found?消息 (因为在?urls?列表中你输入的没有被匹配到). 为了让其运行的时候不需要添加?code.py, 启用mod_rewrite 法则 (查看如下)。
Walter 还有一些额外建议.
https://www.mems-exchange.org/software/scgi/ 从 http://www.mems-exchange.org/software/files/mod_scgi/ 下载mod_scgi?代码 windows apache 用户: 编辑 httpd.conf:
LoadModule scgi_module Modules/mod_scgi.soSCGIMount / 127.0.0.1:8080重启apache,并在命令行中如下方式启动code.py:
python code.py 127.0.0.1:8080 scgi打开你的浏览器,访问127.0.0.1 It's ok!
mod_python 运行方式如同FastCGI, 但不是那么方便配置。
对于 Python 2.5 按照如下:
cd /usr/lib/python2.5/wsgiref# or in windows: cd /python2.5/lib/wsgirefwget -O modpython_gateway.py http://projects.amor.org/misc/browser/modpython_gateway.py?format=raw# or fetch the file from that address using your browser对于 Python <2.5 按照如下:
cd /usr/lib/python2.4/site-packages# or in windows: cd /python2.4/lib/site-packagessvn co svn://svn.eby-sarna.com/svnroot/wsgiref/wsgirefcd wsgirefwget -O modpython_gateway.py http://projects.amor.org/misc/browser/modpython_gateway.py?format=raw# or fetch the file from that address using your browser 重命名?code.py?为?codep.py?或别的名字, 添加:
main = web.wsgifunc(web.webpyfunc(urls, globals()))在?.htaccess?中, 添加:
AddHandler python-program .pyPythonHandler wsgiref.modpython_gateway::handlerPythonOption wsgi.application codep::main你应该希望添加?RewriteRule?将?/?指向?/codep.py/
确保访问?/codep.py/?的时候有添加最后的?/。 否则,你将会看到一条错误信息,比如?A server error occurred. Please contact the administrator.
mod_wsgi 是一个新的Apache模块?通常优于mod_python?用于架设WSGI应用,它非常容易配置。
在?code.py?的最后添加:
application = web.wsgifunc(web.webpyfunc(urls, globals()))mod_wsgi 提供?许多可行方法?来实现WSGI应用, 但一种简单的方法是添加以下到 .htaccess:
<Files code.py> SetHandler wsgi-script Options ExecCGI FollowSymLinks</Files>如果在apache的 error.log 文件中出现 "ImportError: No module named web", 在导入web之前,你可能需要在code.py中尝试设置绝对路径:
import sys, osabspath = os.path.dirname(__file__)sys.path.append(abspath)os.chdir(abspath)import web同时, 你可能需要查看?WSGI应用的常见问题的 "Application Working Directory" 部分。
最终应该可以访问?http://example.com/code.py/。
如果希望 web.py 能够通过 'http://example.com' 访问,代替使用 'http://example.com/code.py/', 添加以下法则到.htaccess?文件:
<IfModule mod_rewrite.c> RewriteEngine on RewriteBase / RewriteCond %{REQUEST_URI} !^/icons RewriteCond %{REQUEST_URI} !^/favicon.ico$ RewriteCond %{REQUEST_URI} !^(/.*)+code.py/ RewriteRule ^(.*)$ code.py/$1 [PT]</IfModule>如果?code.py?在子目录?myapp/中, 调整 RewriteBase 为?RewriteBase /myapp/。 如果还有一些静态文件如CSS文件和图片文件, 复制这些并改成你需要的地址。