◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
bottle 是一个轻量级且快速的 python 微型 web 框架。它的设计简单易用,非常适合小型 web 应用程序、原型或 api。
主要特点:
单文件部署:bottle 可以完全从单个 python 文件运行,除了 python 标准库之外没有任何依赖项。这使得部署和维护小型项目变得容易。
内置 http 服务器:它带有内置服务器,但也可以配置为在其他 wsgi 兼容服务器(如 gunicorn 或 uwsgi)上运行。
立即学习“Python免费学习笔记(深入)”;
路由:bottle 提供简单而强大的路由功能。它将 url 映射到处理请求并返回响应的函数。
模板:它有一个内置的模板引擎,让您轻松创建动态 html 内容。
插件:bottle 支持插件,这些插件是可以添加以扩展其功能的组件。常见插件包括对 sqlite、mysql 或 mongodb 等数据库的支持。
符合 wsgi:bottle 完全符合 wsgi,这意味着它可以与其他 wsgi 兼容的应用程序和中间件集成。
在开始使用 bottle 之前,您需要先安装它。 bottle是一个纯python包,安装很简单:
pip 安装瓶子
这将安装 bottle 框架并使其可在您的项目中使用。
以下是如何使用 bottle 创建基本 web 应用程序:
从瓶子导入瓶子,运行
app = bottle()
@app.route('/hello')
def hello():
返回“你好,世界!”
运行(应用程序,主机='localhost',端口=8080)
说明:
bottle() 创建一个应用程序实例。该实例用于定义路由和处理请求。
@app.route('/hello') 是一个定义路由的装饰器,将 url /hello 映射到函数 hello()。每当访问此 url 时,都会调用 hello() 函数,并输出字符串“hello, world!”作为响应返回。
run(app, host='localhost', port=8080) 启动内置 web 服务器,使您的应用程序可以通过 http://localhost:8080/hello 访问。
要运行上面的示例,请将代码保存到文件中,例如 app.py,然后执行它:
python app.py
在浏览器中导航到 http://localhost:8080/hello,您应该看到“hello, world!”显示。
理解这些核心概念将帮助您使用 bottle 构建更复杂的应用程序:
4.1。路线
路由是一种定义应用程序应如何处理特定 url 的方法。 bottle 使用装饰器将 url 映射到 python 函数。
例如:
@app.route('/hello/')
def 问候(名字):
return f“你好,{name}!”
这里是一个动态段,这意味着如果您访问http://localhost:8080/hello/john,输出将是“hello, john!”。
4.2。请求和响应
request:请求对象包含服务器接收到的http请求的信息,例如标头、查询参数、表单数据等
来自瓶子进口请求
@app.route('/login', method='post')
def 登录():
username = request.forms.get('用户名')
密码 = request.forms.get('密码')
return f"用户名:{用户名},密码:{密码}"
此示例演示如何提取通过 post 请求发送的表单数据。
响应:链接到路由的函数可以返回字符串(html)、json或其他响应对象。 bottle 允许您设置标头、状态代码等。
来自瓶子导入响应
@app.route('/json')
def json_example():
response.content_type = 'application/json'
return '{"name": "john", "age": 30}'
4.3。模板
模板允许您将 html 内容与应用程序的逻辑分开。 bottle 包含一个基本模板引擎,使这一切变得简单:
从瓶子导入模板
@app.route('/hello/')
def 你好(名字):
return template('hello {{name}}!', name=name)
template() 渲染一个模板字符串,替换 name 的值。
您还可以使用外部模板文件:
你好{{name}}!
@app.route('/hello/')
def 你好(名字):
return template('hello', name=name)
4.4。静态文件
bottle 可以在开发过程中提供静态文件,例如 css、javascript 或图像:
从瓶子导入静态文件
@app.route('/static/')
defserve_static(文件名):
return static_file(文件名, root='/path/to/static/files')
将 '/path/to/static/files' 替换为存储静态文件的目录。
4.5。插件
bottle 允许您使用插件扩展功能。例如,您可以使用数据库插件轻松地将数据库与您的应用程序集成:
从 bottle.ext 导入 sqlite
app.install(sqlite.plugin(dbfile='/path/to/database.db'))
4.6。错误处理
您可以使用 bottle 的错误处理功能创建自定义错误页面:
@app.error(404)
def error404(错误):
return '抱歉,该页面不存在!'
4.7。中间件
bottle 符合 wsgi,这意味着您可以使用中间件来添加功能,例如日志记录、身份验证等
简单中间件示例:
simplemiddleware 类:
def init(self, app):
self.app = 应用程序
def __call__(self, environ, start_response): print("Middleware: Received request") return self.app(environ, start_response)
app = simplemiddleware(app)
让我们构建一个结合我们所涵盖的所有内容的示例:
来自 bottle 导入 bottle、运行、请求、模板、静态文件
app = bottle()
@app.route('/')
def home():
返回模板('
@app.route('/greet', method='post')
def 问候():
name = request.forms.get('name')
return template('你好,{{name}}!', name=name)
@app.route('/static/')
defserve_static(文件名):
return static_file(文件名, root='./static')
@app.error(404)
def error404(错误):
return '页面未找到。请检查网址。'
运行(应用程序,主机='localhost',端口=8080)
说明:
主页:显示用户可以输入名称的表单。
问候语路由:处理表单输入并显示问候语。
静态文件:演示如何提供 css、js 或图像。
错误处理:显示自定义 404 错误消息。
优点:
轻量级:只有一个文件,除了python标准库之外没有任何依赖项。
简单:易于学习和使用,非常适合小型项目或原型。
可扩展:支持插件和中间件,因此它可以随着您的项目一起成长。
用例:
构建 api 或微服务
快速原型制作
中小型 web 应用程序
在基于 python 的工具或脚本中嵌入 web 服务器
结论
对于希望快速构建小型 web 应用程序而无需进行太多设置的开发人员来说,bottle 是一个绝佳的选择。了解路由、模板、请求和响应的工作原理将使您能够创建有效且高效的应用程序。使用正确的插件和中间件,您可以扩展 bottle 的功能以适应更复杂的用例。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。