一、简单的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使用

原文出处:https://www.cnblogs.com/wupeiqi/articles/5341480.html