[Medusa-dev] psp_handler - embed python in HTML like ASP
[Medusa-dev] psp_handler - embed python in HTML like ASP
[Medusa-dev] psp_handler - embed python in HTML like ASP
Kevin Smith smithk at attbi.com
Sun Apr 27 13:27:49 EDT 2003
- Previous message: [Medusa-dev] Small patch to move URI unquoting in http_server.py
- Next message: [Medusa-dev] Channel not closing after error
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
Hi, I have created a psp_handler (Python Server Pages???) for medusa
based on the script_handler. This handler lets you mix HTML with python
like ASP pages. The handler can be installed on the server in the sam
manner as the script handler.
Here is an example hello.psp file... <html>
<title>Medusa PSP Handler</title>
<body>
<%psp
print "hello world"
%>
</body>
</html> I have been using this handler for much more useful applications of
course :). Just wrap the inline python with <%psp ... %> tags. Here is the handler...
# -*- Mode: Python -*- # This is a simple python server pages script handler. # A note about performance: This is really only suited for 'fast'
# scripts: The script should generate its output quickly, since the
# whole web server will stall otherwise. This doesn't mean you have
# to write 'fast code' or anything, it simply means that you shouldn't
# call any long-running code, [like say something that opens up an
# internet connection, or a database query that will hold up the
# server]. If you need this sort of feature, you can support it using
# the asynchronous I/O 'api' that the rest of medusa is built on. [or
# you could probably use threads] # Put your script into your web docs directory (like a cgi-bin
# script), make sure it has the correct extension [see the overridable
# script_handler.extension member below].
#
# There's lots of things that can be done to tweak the restricted
# execution model. Also, of course you could just use 'execfile'
# instead (this is now the default, see class variable
# script_handler.restricted) import rexec
import re
import string
import StringIO
import sys import counter
import default_handler
import producers
from script_handler import collector unquote = default_handler.unquote def iif(expression,truepart,falsepart):
if expression:
return truepart
else:
return falsepart class psp_handler: extension = 'psp' # the following should not get overridden!
fp = None
script = ''
data = ''
insidePsp = False script_regex = re.compile (
r'.*/([^/]+\.%s)' % extension,
re.IGNORECASE
) def __init__ (self,
filesystem,restricted=False,preserveNamespace=True):
self.filesystem = filesystem
self.hits = counter.counter()
self.exceptions = counter.counter()
self.restricted = restricted
self.preserveNamespace = preserveNamespace def match (self, request):
[path, params, query, fragment] = request.split_uri()
m = self.script_regex.match (path)
return (m and (m.end() == len(path))) def handle_request (self, request): [path, params, query, fragment] = request.split_uri() while path and path[0] == '/':
path = path[1:] if '%' in path:
path = unquote (path) if not self.filesystem.isfile (path):
request.error (404)
return
else: self.hits.increment() request.script_filename = self.filesystem.translate (path) if request.command in ('PUT', 'POST'):
# look for a Content-Length header.
cl = request.get_header ('content-length')
length = int(cl)
if not cl:
request.error (411)
else:
collector (self, length, request)
else:
self.continue_request (
request,
StringIO.StringIO() # empty stdin
) def continue_request (self, request, stdin):
temp_files = stdin, StringIO.StringIO(), StringIO.StringIO()
old_files = sys.stdin, sys.stdout, sys.stderr try:
sys.request = request
sys.stdin, sys.stdout, sys.stderr = temp_files
try:
#get the path from the uri and open the file with the
filesystem class
try:
file =
self.filesystem.open(request.split_uri()[0],'r')
except IOError:
request.error (404)
return
self.fp = producers.file_producer(file)
self.dissect_psp(request)
request.reply_code = 200
except:
request.reply_code = 500
self.exceptions.increment()
finally:
sys.stdin, sys.stdout, sys.stderr = old_files
del sys.request i,o,e = temp_files if request.reply_code != 200:
s = e.getvalue()
else:
s = o.getvalue() request['Content-Length'] = len(s)
request.push (s)
request.done() def status (self):
return producers.simple_producer (
'<li>PSP - Python Server Pages Handler'
+ '<ul>'
+ ' <li><b>Hits:</b> %s' % self.hits
+ ' <li><b>Exceptions:</b> %s' % self.exceptions
+ ' <li><b>Execution Mode:</b>%s' %
iif(self.restricted,'Restricted','Unrestricted' )
+ ' <li><b>Namespace:</b>:%sPreserved' %
iif(self.preserveNamespace,'','not ' )
+ '</ul>'
) ## this function reads the file using the file producer and sends
## the data to the client until the script start tag '<%psp'
## is found. All of the text between the script start marker
## '<%psp' and the end script marker '%>' is executed as
## python script.
def dissect_psp(self,request):
self.insidePsp = False
self.script = ''
while not self.fp.done:
self.data=self.fp.more()
#print the HTML to the stdout, execute the python script...
while self.data:
if self.insidePsp:
sectionend=self.data.find("%>")
if (sectionend == -1):
#end of script section is not in the current
chunk
self.script += self.data
self.data = ''
else:
#end of script section is within the current
chunk
self.script += self.data[:sectionend]
self.data = self.data[sectionend+len("%>"):]
del sectionend
if self.preserveNamespace:
if self.restricted:
r = rexec.RExec()
try:
if self.restricted:
r.s_exec (self.script)
else:
exec (self.script)
request.reply_code = 200
except:
request.reply_code = 500
self.exceptions.increment()
else:
self.script_exec(request,self.script)
self.script = ''
self.insidePsp = False
else:
sectionend=self.data.find("<%psp")
if (sectionend == -1):
#end of HTML section is not in the current chunk
print self.data
self.data = ''
else:
#end of HTML section is within the current chunk
print self.data[:sectionend]
self.data = self.data[sectionend+len("<%psp"):]
self.insidePsp = True # this function will eliminate any of the unnecessary objects
# from appearing in the script namespace. print dir() should
# return only self,request, and script. # one drawback with this method is that namespace is cleared
# for each section of script in the document. def script_exec(self,request,script):
# for debugging we can send a copy of the script to the browser.
# this presents security issues so this next line should be
# commented out.
if self.restricted:
r = rexec.RExec()
try:
if self.restricted:
r.s_exec (script)
else:
exec (script)
request.reply_code = 200
except:
request.reply_code = 500
self.exceptions.increment()
- Previous message: [Medusa-dev] Small patch to move URI unquoting in http_server.py
- Next message: [Medusa-dev] Channel not closing after error
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
[Medusa-dev] psp_handler - embed python in HTML like ASP的更多相关文章
- a simple and universal interface between web servers and web applications or frameworks: the Python Web Server Gateway Interface (WSGI).
WSGI is the Web Server Gateway Interface. It is a specification that describes how a web server comm ...
- 跟着老男孩教育学Python开发【第一篇】:初识Python
Python简介 Python前世今生 Python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...
- Python开发【第一篇】:初识Python
初识python 一.python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...
- python入门简介
Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC ...
- Python开发【第二篇】:初识Python
Python开发[第二篇]:初识Python Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏 ...
- python之路一
Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC ...
- 初识Python(一)
Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...
- Embeding Python & Extending Python with FFPython
Introduction ffpython is a C++ lib, which is to simplify tasks that embed Python and extend Python. ...
- [转载]Python模块学习 ---- subprocess 创建子进程
[转自]http://blog.sciencenet.cn/blog-600900-499638.html 最近,我们老大要我写一个守护者程序,对服务器进程进行守护.如果服务器不幸挂掉了,守护者能即时 ...
随机推荐
- 链表的基本操作(Basic Operations on a Linked List)
链表可以进行如下操作: 创建新链表 增加新元素 遍历链表 打印链表 下面定义了对应以上操作的基本函数. 创建新链表 新链表创建之后里面并没有任何元素,我们要为数据在内存中分配节点,再将节点插入链表.由 ...
- 【CF 189A Cut Ribbon】dp
题目链接:http://codeforces.com/problemset/problem/189/A 题意:一个长度为n的纸带,允许切割若干次,每次切下的长度只能是{a, b, c}之一.问最多能切 ...
- phpWeb
Ruby on Rails框架在REST走得很前,开发时默认都按照RESTful风格搭建. <RESTful Web Services>是本好书 SOAP
- Unity 脚本函数生命周期
Awake(),一般我们在这里做一些组件的获得,比如使用getcomponent方法. Start(),我们可以在这里给变量赋值. FixUpdate(),固定更新,因为这里得更新速度为固定(可以在T ...
- WEB应用知识一二三
1.HTTP协议 |--基于请求(Request)和响应(Response)的无状态通讯协议 浏览器和WEB应用程序通过HTTP进行通信.客户端通过URL对指定服务器要求特定位置的数据 |--POST ...
- 【转】PF_NETLINK应用实例NETLINK_KOBJECT_UEVENT具体实现--udev实现原理
相对于linux来说,udev还是一个新事物.然而,尽管它03年才出现,尽管它很低调(J),但它无疑已经成为linux下不可或缺的组件了.udev是什么?它是如何实现的?最近研究Linux设备管理时, ...
- iOS面试知识点
1 iOS基础 1.1 父类实现深拷贝时,子类如何实现深度拷贝.父类没有实现深拷贝时,子类如何实现深度拷贝. 深拷贝同浅拷贝的区别:浅拷贝是指针拷贝,对一个对象进行浅拷贝,相当于对指向对象的指针进行复 ...
- python之路-模块安装 paramiko
paramiko介绍(全是洋文,看不懂啊,赶紧有道翻译吧,等有朝一日,我去报个华尔街): "Paramiko" is a combination of the esperanto ...
- 一步一步学数据结构之n--n(Prim算法)
在这里说下最小连通网的Prim算法: 而Kruskal算法,http://blog.csdn.net/nethanhan/article/details/10050735有介绍,大家可以去看下! Pr ...
- 关于Latch
Latch是什么 Latch是SQL Server引擎保证内存中的结构的一致性的轻量同步机制.比如索引,数据页和内部结构(比如非叶级索引页).SQL Server使用Buffer Latch保护缓冲池 ...