web.py框架之基本应用
一、基本应用
1.1 Hello World!
# coding:utf-8 import web urls = (
"/.*", "Tk_online"
) app = web.application(urls, globals()) class Tk_online(object): def GET(self):
return "Hello World!" if __name__ == "__main__":
app.run()
1.2 提供静态文件
在当前应用的目录下创建static目录,将需要提供访问的静态文件放里面即可,比如JS,CSS等静态文件。
直接访问http://localhost/static/ 默认返回static里面的index.py文件
直接访问http://localhost/static/logo.png 将访问到logo.png这个文件
1.3 URL控制
web.py的URL控制模式是简单的、强大的、灵活的。在每个应用的最顶部,你通常看到整个URL调度模式被定义到元祖中:
urls = (
"/online/?", "online",
"/log", "log",
"/timer", "timer"
)
你可以捕捉URL的参数,然后用在处理类中:
"/users/list/(.+)", "list_users"
在list/后面这块儿会被捕捉然后作为参数用在GET或POST:
class list_user(object): def GET(self):
return "Listing info about user: {0}".format(name)
同样,后端获取前端的参数也可以用web.input()获取。
开发子应用的时候需要注意:
为了更好的控制大型web应用,web.py支持子应用。在为子应用设计URL模式的时候,记住去的路经是父应用剥离后的。
比如:你在主应用定义了URL "/blog"跳转到"blog"子应用,那么你在子应用中的所有URL都是以"/"开头的,而不是"/blog"。
完整应用路径如下:
webdemo
blog
blog.py
__init__.py
Main.py
Main.py文件
import web
from blog import blog urls = (
"/blog", blog.app # 注意,这里的blog是blog.py的blog
) app = web.application(urls, globals()) if __name__ == "__main__":
app.run()
blog.py文件
import web urls = (
"/namelist", "Namelist"
) app = web.application(urls, globals()) class Namelist(object):
def GET(self):
return "hello"
1.4 跳转(seeother)和重定向(redirect)
class SamePage(object):
def GET(self):
return web.seeother("/namelist")
注意:web.seeother和web.redirect不支持0.3以下版本。
# seeother和redirect的区别
seeother和redirect似乎可以做同样的事情,但通常来说,redirect并不太友好。
因为redirect发送的是301消息——这是永久重定向。因为大多数Web浏览器会缓存新的重定向,所以当我们再次执行该操作时,会自动访问重定向的新网址。
很多时候,这不是我们所想要的结果。所以在提交表单时,尽量使用seeother。
但是在下面要提交的这种场合,用redirect确实对恰当的:我们已经改变了网站的网址结构,但是仍想让用户书签/收藏夹中的旧网址不生效。
1.5 使用子应用
# 子应用 blog.py import web urls = (
"", "reblog",
"/(.*)", "blog"
)
app_blog = web.application(urls, globals()) class reblog:
def GET(self):
raise web.seeother("/") class blog:
def GET(self, path):
return "blog" + path
# 主应用 code.py import web
import blog urls = (
"/blog", blog.app_blog,
"/(.*)", "index"
) class index:
def GET(self, path):
return "hello" + path app = web.application(urls, globals()) if __name__ == "__main__":
app.run()
1.6 提供XML访问
根据要访问的XML文件(如response.xml)创建一个XML模板。如果XML中有变量,就使用相应的模板标签进行替换。
下面是一个例子:
$def with(code)
<?xml version="1.0">
<RequestNotification-Response>
<Status>$code</Status>
</RequestNotification-Response>
为了提供这个XML,需要创建一个单独的web.py程序(如response.py),他要包含下面的代码。
注意:要用"web.header('Content-Type', 'text/xml')"来告知客户端——正在发送的是一个XML文件。
import web render = web.template.render('templates/', cache=False) urls = (
"/(.*)", "index"
) app = web.application(urls, globals()) class index:
def GET(self, code):
web.header("Content-Type", "text/xml")
return render.index(code) web.webapi.internalerror = web.debugerror if __name__ == "__main__":
app.run()
1.7 从post读取原始数据
class RequestHandler:
def POST(self):
data = web.data() # 通过这个方法可以取到数据
第一章内容结束!
web.py框架之基本应用的更多相关文章
- 【Python】【Web.py】详细解读Python的web.py框架下的application.py模块
详细解读Python的web.py框架下的application.py模块 这篇文章主要介绍了Python的web.py框架下的application.py模块,作者深入分析了web.py的源码, ...
- web.py框架入门
在使用微信搭建公众平台的时候,使用的是web.py这个方便简单的框架,学习一下. 框架文档:http://webpy.org/docs/0.3/tutorial.zh-cn 按照文档的内容写一遍程序 ...
- Web.py 框架学习笔记 - URL处理
最近由于工作需要开始学习基于python的web应用框架web.py.为了方便学习,将学习心得逐日记下以便日后复习. URL 模板: web.py提供了一套url处理的模板,在python工程中,只需 ...
- web.py框架之高级应用
二.高级应用 2.1 web.ctx 获取客户端信息,比如:来源页面.客户端浏览器类型等. web.ctx基于 threadeddict类,又被叫做 ThreadDict.这个类创建了一个类似字典(d ...
- web.py框架之i18n支持
问题: 在web.py的模板文件中, 如何得到i18n的支持? Solution: 项目目录结构: proj/ |- code.py |- i18n/ |- messages.po |- en_US/ ...
- Web.py 框架学习笔记 - ctx
摘要: ctx用于存取web请求的环境变量,基于ThreadedDict类进行实例化.ThreadedDict类可实例化字典类型的对象,该对象某些属性可用于存取处理线程的id. 这样字典化实例的线程池 ...
- (转)Nginx + uwsgi + web.py + MySQLdb
一.背景知识: Web服务器上有多种方式运行Python: 传统上的CGI方式:基本已被淘汰 mod_python的模块方式:仍在广泛使用,但生产环境中也被逐步淘汰 uwsgi方式:目前生产环境下最受 ...
- python web.py操作mysql数据库,实现对数据库的增删改查操作
使用web.py框架,实现对mysql数据库的增删改查操作: 该示例代码中连接的是本地数据库testdb,user表,表结构比较简单,只有两个字段:mobile和passwd,类型均为字符型 实际应用 ...
- python web.py实现简单的get和post请求
使用web.py框架,实现简单的get和post请求: py文件名:mytest.py import web urls = ( '/', 'hello' ) app = web.application ...
随机推荐
- H5C301
标题H5C301 1.html5 h5最新版本.所有主流浏览器都支持h5.但仅ie9及以上支持h5 改变了用户与文档的交互方式:多媒体 新增了其他的特性:语义,本地存储,网页多媒体 抛弃了不合理的标签 ...
- import tensorflow 报错: tf.estimator package not installed.
import tensorflow 报错: tf.estimator package not installed. 解决方案1: 安装 pip install tensorflow-estimator ...
- PHP性能分析——xhprof(window 安装xhporf)
1 下载xhprof的php扩展 因为官方的xhprof不支持php7,所以采用tideways版本的xhprof 下载地址:windows版tideways_xhprof 将windows版的dll ...
- 经纬度编码方法推荐-plus code简介
今天罗孚为大家推荐一种经纬度编码的方法--plus code,原名open location code,是Google于2014年发明的,旨在将表示地理位置的经纬度通过算法推导成一个字符串. plus ...
- mingw 构建 gdal 2.1.2
目录 1.准备 2.生成Makefile 3.编译 4.编译遇到错误及解决办法 1.生成静态库时候ar提示参数列表太长 2.生成动态库时候g++提示参数列表太长 前两日有人在oschian上问我min ...
- Nginx——location常见配置指令,alias、root、proxy_pass
1.[alias] 别名配置,用于访问文件系统,在匹配到location配置的URL路径后,指向[alias]配置的路径.如: location /test/ { alias /home/sftp/i ...
- (原)tensorflow使用eager在mnist上训练的简单例子
转载请注明出处: https://www.cnblogs.com/darkknightzh/p/9989586.html 代码网址: https://github.com/darkknightzh/t ...
- lua 源码分析之线程对象lua_State
lua_State 中放的是 lua 虚拟机中的环境表.注册表.运行堆栈.虚拟机的上下文等数据. 从一个主线程(特指 lua 虚拟机中的线程,即 coroutine)中创建出来的新的 lua_Stat ...
- users-and-groups-in-linux
https://www.tecmint.com/compress-files-and-finding-files-in-linux/ https://www.tecmint.com/manage-us ...
- 【转载】最强NLP预训练模型!谷歌BERT横扫11项NLP任务记录
本文介绍了一种新的语言表征模型 BERT--来自 Transformer 的双向编码器表征.与最近的语言表征模型不同,BERT 旨在基于所有层的左.右语境来预训练深度双向表征.BERT 是首个在大批句 ...