一、简单的Bottle框架
1)bottle框架简介
安装 pip install bottle
Bottle是一个快速、简洁、轻量级的基于WSIG的微型Web框架。
此框架只由一个 .py 文件,除了Python的标准库外,其不依赖任何其他模块。
bottle简介
2)bottle框架的组成部分
1、路由系统,将不同请求交由指定函数处理
2、模板系统,将模板中的特殊语法渲染成字符串,值得一说的是Bottle的模板引擎可以任意指定:Bottle内置模板、mako、jinja2、cheetah
3、公共组件,用于提供处理请求相关的信息,如:表单数据、cookies、请求头等
4、服务,Bottle默认支持多种基于WSGI的服务
bottle框架的组成部分
Bottle默认支持多种基于WSGI的服务
server_names = {
'cgi': CGIServer,
'flup': FlupFCGIServer,
'wsgiref': WSGIRefServer,
'waitress': WaitressServer,
'cherrypy': CherryPyServer,
'paste': PasteServer,
'fapws3': FapwsServer,
'tornado': TornadoServer,
'gae': AppEngineServer,
'twisted': TwistedServer,
'diesel': DieselServer,
'meinheld': MeinheldServer,
'gunicorn': GunicornServer,
'eventlet': EventletServer,
'gevent': GeventServer,
'geventSocketIO':GeventSocketIOServer,
'rocket': RocketServer,
'bjoern' : BjoernServer,
'auto': AutoServer,
}
WSGI的服务
3)框架的基本使用
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template,Bottle
root = Bottle()
@root.route('/hello')
def index():
# return "Hello World"
return template('<b>Hello {{ name }}</b>!',name="user")
root.run(host='localhost',port=8080)
bottle简单使用
访问: http://localhost:8080/hello
4)对于form表单提前,python后端取值
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>login</title>
</head>
<body>
<h1>Bottle登录系统</h1>
<form action="/login/" method="POST">
<input type="text" name="user" placeholder="用户名"/>
<input type="password" name="pwd" placeholder="密码"/>
<input type="submit" value="提交"/>
</form>
</body>
</html>
login.html
@root.route('/login/',method=["POST","GET"])
def login():
if request.method == "GET":
return template('login.html')
else:
u = request.forms.get('user')
p = request.forms.get('pwd')
return redirect('/index/')
request.forms.get()取值
二 、路由系统
1)静态路由
@root.route('/hello/')
def index():
return template('<b>Hello {{name}}</b>!', name="User")
静态路由
2)动态路由
@root.route('/wiki/<pagename>')
def callback(pagename):
...
@root.route('/object/<id:int>')
def callback(id):
...
@root.route('/show/<name:re:[a-z]+>')
def callback(name):
...
@root.route('/static/<path:path>')
def callback(path):
return static_file(path, root='static')
动态路由
3)请求方法路由
@root.route('/hello/', method='POST')
def index():
...
@root.get('/hello/')
def index():
...
@root.post('/hello/')
def index():
...
@root.put('/hello/')
def index():
...
@root.delete('/hello/')
def index():
...
# 第一种,写在一起
@root.route('/login/',method=["POST","GET"])
def login():
if request.method == "GET":
return template('login.html')
else:
return redirect('/index/')
# 第二种,分开写
@root.route('/login/',method="POST")
def index():
return template('login.html')
@root.route('/login/',method="GET")
def index():
return template('login.html')
请求方法路由
4)二级路由,路由分发
主路由编辑
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template, Bottle
from bottle import static_file
root = Bottle()
@root.route('/hello/')
def index():
return template('<b>Root {{name}}</b>!', name="Alex")
from framwork_bottle import app01
from framwork_bottle import app02
root.mount('app01', app01.app01)
root.mount('app02', app02.app02)
root.run(host='localhost', port=8080)
总路由编辑
二级路由编辑
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template, Bottle
app01 = Bottle()
@app01.route('/hello/', method='GET')
def index():
return template('<b>App01</b>!')
二级路由
三、模板系统
1)配置模板使用路径
import bottle
bottle.TEMPLATE_PATH.append('./templates/')
2)模板语言的常用方法
2.1)前后端结合
路由传值给前端模板
@root.route('/index/',method="GET")
def index():
user_list = [
{'id':1,'name':'root','age':18},
{'id':1,'name':'root','age':18},
{'id':1,'name':'root','age':18},
{'id':1,'name':'root','age':18},
]
return template('index.html',name='superbody',user_list=user_list)
python后端传值
前端调用值
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>index</title>
</head>
<body>
<ul>
<!--for循环-->
{{name}}
% for item in user_list:
<li>{{item['id']}}-{{item['name']}}</li>
% end
<!--自定义常量-->
% laogao = "guaizi"
{{laogao}}
</ul>
<!--有值就取,没值就默认-->
<div>{{get('age','123')}}</div>
</body>
</html>
index.html
2.2)include 引用文件的标签
<h1>{{title}}</h1>
被引用的文件,tpl.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--引用文件,赋值-->
% include('tpl.html',title='搞事情')
</body>
</html>
index.html调用tpl.html
2.3) rebase 引用文件的标签
<html>
<head>
<title>{{title or 'No title'}}</title>
</head>
<body>
{{!base}}
</body>
</html>
base.html
导入基础模板
% rebase('base.tpl', title='Page Title')
<p>Page Content ...</p>
2.4)常用方法归纳
1、单值
2、单行Python代码
3、Python代码快
4、Python、Html混合
示例
<h1>1、单值</h1>
{{name}}
<h1>2、单行Python代码</h1>
% s1 = "hello"
<h1>3、Python代码块</h1>
<%
# A block of python code
name = name.title().strip()
if name == "Alex":
name="seven"
%>
<h1>4、Python、Html混合</h1>
% if True:
<span>{{name}}</span>
% end
<ul>
% for item in name:
<li>{{item}}</li>
% end
</ul>
html模板语音归纳
2.5)如果没有该值的情况下的默认值设置
# 检查当前变量是否已经被定义,已定义True,未定义False
defined(name)
# 获取某个变量的值,不存在时可设置默认值
get(name, default=None)
<div>{{get('age','123')}}</div>
# 如果变量不存在时,为变量设置默认值
setdefault(name, default)
默认值
2.6){{ wupeiqi() }} 。定义函数,python后端定义函数,html前端调用函数执行
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import template, Bottle,SimpleTemplate
root = Bottle()
def custom():
return '123123'
@root.route('/hello/')
def index():
# 默认情况下去目录:['./', './views/']中寻找模板文件 hello_template.html
# 配置在 bottle.TEMPLATE_PATH 中
return template('hello_template.html', name='alex', wupeiqi=custom)
root.run(host='localhost', port=8080)
main.py
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<h1>自定义函数</h1>
{{ wupeiqi() }}
</body>
</html>
hello_template.html
2.6.1){{ !wupeiqi() }}。渲染引用的html标签
被调用的python函数
def custom():
return '<h1>hello world</h1>'
前端使用
<body>
<h1>自定义函数</h1>
{{ !wupeiqi() }}
</body>
2.7)替换模板。
from bottle import jinja2_template
@root.route('/login/',method=["POST","GET"])
def login():
return jinja2_template('login.html')
替换模板
jinja2_template模板与django模板使用一样
四、公共组件
1)request:Bottle中的request其实是一个LocalReqeust对象,其中封装了用户请求的相关信息
request.headers
请求头信息
request.query
get请求信息
request.forms
post请求信息
request.files
上传文件信息
request.params
get和post请求信息
request.GET
get请求信息
request.POST
post和上传信息
request.cookies
cookie信息
request.environ
环境相关相关
请求信息
2)response:Bottle中的request其实是一个LocalResponse对象,其中框架即将返回给用户的相关信息
response
response.status_line
状态行
response.status_code
状态码
response.headers
响应头
response.charset
编码
response.set_cookie
在浏览器上设置cookie
response.delete_cookie
在浏览器上删除cookie
View Code
五、Bottle支持的WSGI
server_names = {
'cgi': CGIServer,
'flup': FlupFCGIServer,
'wsgiref': WSGIRefServer,
'waitress': WaitressServer,
'cherrypy': CherryPyServer,
'paste': PasteServer,
'fapws3': FapwsServer,
'tornado': TornadoServer,
'gae': AppEngineServer,
'twisted': TwistedServer,
'diesel': DieselServer,
'meinheld': MeinheldServer,
'gunicorn': GunicornServer,
'eventlet': EventletServer,
'gevent': GeventServer,
'geventSocketIO':GeventSocketIOServer,
'rocket': RocketServer,
'bjoern' : BjoernServer,
'auto': AutoServer,
}
wsgi服务
使用时,只需在主app执行run方法时指定参数即可:
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from bottle import Bottle
root = Bottle()
@root.route('/hello/')
def index():
return "Hello World"
# 默认server ='wsgiref',性能最差,测试专用
root.run(host='localhost', port=8080, server='wsgiref')
main.py
使用Python内置模块wsgiref,如果想要使用其他时,则需要首先安装相关类库,然后才能使用
六、数据库操作
可手写orm框架,或者pymysql使用