[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

 


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()



 


[Medusa-dev] psp_handler - embed python in HTML like ASP的更多相关文章

  1. 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 ...

  2. 跟着老男孩教育学Python开发【第一篇】:初识Python

    Python简介 Python前世今生 Python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...

  3. Python开发【第一篇】:初识Python

    初识python 一.python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...

  4. python入门简介

    Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC ...

  5. Python开发【第二篇】:初识Python

    Python开发[第二篇]:初识Python   Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏 ...

  6. python之路一

    Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC ...

  7. 初识Python(一)

    Python简介 Python前世今生 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解 ...

  8. Embeding Python & Extending Python with FFPython

    Introduction ffpython is a C++ lib, which is to simplify tasks that embed Python and extend Python. ...

  9. [转载]Python模块学习 ---- subprocess 创建子进程

    [转自]http://blog.sciencenet.cn/blog-600900-499638.html 最近,我们老大要我写一个守护者程序,对服务器进程进行守护.如果服务器不幸挂掉了,守护者能即时 ...

随机推荐

  1. QQ聊天界面的布局和设计(IOS篇)-第二季

    QQChat Layout - 第二季 本来第二季是快写好了, 也花了点功夫, 结果gitbook出了点问题, 给没掉了.有些细节可能会一带而过, 如有疑问, 相互交流进步~. 在第一季中我们完成了Q ...

  2. IO-APIC

    MP-BIOS bug :8254 timer not connected to IO-APIC解决办法 云计算中在基于一个template image instance vmServer时出现上述的 ...

  3. Hibernate自定义主键

    Hibernate自定义主键,通过此方法可以解决一此特殊的主键ID,在了解自定义主键时,先了解下Hibernate有自带的10种生成主键方法. 1) assigned主键由外部程序负责生成,无需Hib ...

  4. C++里消除Wunused

    编译程序时,有一大堆警告总是不爽的.别人的代码也就忍了,不好去改.自己的可没法忍.看看C++里怎么消除Wunused警告. 先来看下面的程序: #include <iostream> in ...

  5. pyqt 动态显示时间方法例子学习

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' import sys,datetime from PyQt4.QtC ...

  6. 浅谈jquery关于select框的取值和赋值

    浅谈jquery关于select框的取值和赋值   jQuery("#select_id").change(function(){}); // 1.为Select添加事件,当选择其 ...

  7. Eclipse上改动Jython代码的Comment颜色

    1.问题起因 依据上一篇文章<MonkeyRunner在Windows下的Eclipse开发环境搭建步骤(兼解决网上Jython配置出错的问题)>搭配好Eclipse上面的MonkeyRu ...

  8. Oracle中drop user和drop user cascade的区别

    drop user : 仅仅是删除用户,drop user username cascade :会删除此用户名下的所有表和视图. userSpecify the user to be dropped. ...

  9. String和StringBuilder 的使用区别

    String 类有不可变性,每次执行操作时都会创建一个新的String对像,需要对该对象分配新的空间. StringBuilder 解决了对字符串重复修改过程中创建大量对象的问题.初始化一个Strin ...

  10. Xcode 常用快捷键及代码自动排版 二

    Xcode常用快捷键,网上找的总结一下,特别是格式化代码 隐藏xcode command+h退出xcode command+q关闭窗口 command+w关闭所有窗口 command+option+w ...