Bottle - Python 轻量级快速微型 Web 框架

bottle - python 轻量级快速微型 web 框架

bottle 是一个轻量级且快速的 python 微型 web 框架。它的设计简单易用,非常适合小型 web 应用程序、原型或 api。

主要特点:

  1. 单文件部署:bottle 可以完全从单个 python 文件运行,除了 python 标准库之外没有任何依赖项。这使得部署和维护小型项目变得容易。

  2. 内置 http 服务器:它带有内置服务器,但也可以配置为在其他 wsgi 兼容服务器(如 gunicorn 或 uwsgi)上运行。

  3. 路由:bottle 提供简单而强大的路由功能。它将 url 映射到处理请求并返回响应的函数。

  4. 模板:它有一个内置的模板引擎,让您轻松创建动态 html 内容。

  5. 插件:bottle 支持插件,这些插件是可以添加以扩展其功能的组件。常见插件包括对 sqlite、mysql 或 mongodb 等数据库的支持。

  6. 符合 wsgi:bottle 完全符合 wsgi,这意味着它可以与其他 wsgi 兼容的应用程序和中间件集成。


  1. 安装瓶子

在开始使用 bottle 之前,您需要先安装它。 bottle是一个纯python包,安装很简单:

pip 安装瓶子

这将安装 bottle 框架并使其可在您的项目中使用。

  1. 创建一个简单的应用程序

以下是如何使用 bottle 创建基本 web 应用程序:

从瓶子导入瓶子,运行

创建 bottle 应用程序的实例

app = bottle()

定义映射到 url 路径的路由

@app.route('/hello')
def hello():
返回“你好,世界!”

在 localhost 和端口 8080 上运行应用程序

运行(应用程序,主机='localhost',端口=8080)

说明:

bottle() 创建一个应用程序实例。该实例用于定义路由和处理请求。

@app.route('/hello') 是一个定义路由的装饰器,将 url /hello 映射到函数 hello()。每当访问此 url 时,都会调用 hello() 函数,并输出字符串“hello, world!”作为响应返回。

run(app, host='localhost', port=8080) 启动内置 web 服务器,使您的应用程序可以通过 http://localhost:8080/hello 访问。

  1. 运行应用程序

要运行上面的示例,请将代码保存到文件中,例如 app.py,然后执行它:

python app.py

在浏览器中导航到 http://localhost:8080/hello,您应该看到“hello, world!”显示。

  1. 关键术语

理解这些核心概念将帮助您使用 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

安装 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)

  1. 构建完整的示例应用程序

让我们构建一个结合我们所涵盖的所有内容的示例:

来自 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 错误消息。

  1. 为什么要用奶瓶?

优点:

轻量级:只有一个文件,除了python标准库之外没有任何依赖项。

简单:易于学习和使用,非常适合小型项目或原型。

可扩展:支持插件和中间件,因此它可以随着您的项目一起成长。

用例:

构建 api 或微服务

快速原型制作

中小型 web 应用程序

在基于 python 的工具或脚本中嵌入 web 服务器

结论

对于希望快速构建小型 web 应用程序而无需进行太多设置的开发人员来说,bottle 是一个绝佳的选择。了解路由、模板、请求和响应的工作原理将使您能够创建有效且高效的应用程序。使用正确的插件和中间件,您可以扩展 bottle 的功能以适应更复杂的用例。

以上就是Bottle - Python 轻量级快速微型 Web 框架的详细内容,更多请关注其它相关文章!