您的位置:

用Python编写简单框架实现Web应用程序

一、Flask框架入门

Flask框架是一个Python Web应用程序开发框架,它可以让开发者轻松地创建Web应用和RESTful API。Flask框架非常简洁和灵活,可以根据项目需求,选择不同的插件和扩展功能。

Flask的基本语法如下:

from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello_world():
    return 'Hello, World!'

上面的代码创建了一个名为app的Flask对象,并使用@app.route('/')装饰器将hello_world()函数注册为Web应用的默认路由。当用户在浏览器中访问http://localhost:5000/时,将会调用hello_world()函数,并返回"Hello, World!"这个字符串。

除了@app.route('/')装饰器,Flask还提供了很多其他装饰器,例如@app.route('/user/:id'),表示带有参数的路由。还有@app.before_request和@app.after_request两个装饰器,可以在请求前后执行相应的操作。

二、SQLite数据库操作

Flask使用SQLite作为默认的数据存储引擎,可以方便地进行数据库操作。SQLite是一种轻量级数据库引擎,不需要安装额外的数据库软件,可以直接使用Python内置的sqlite3模块操作SQLite数据库。

下面是一个使用SQLite数据库的示例:

import sqlite3

def connect_db():
    conn = sqlite3.connect('my_database.db')
    return conn

def query_db(query, args=(), one=False):
    conn = connect_db()
    cur = conn.execute(query, args)
    rv = cur.fetchall()
    cur.close()
    conn.close()
    return (rv[0] if rv else None) if one else rv

@app.route('/user/:id')
def get_user(id):
    user = query_db('select * from users where id = ?', [id], one=True)
    return 'User: %s' % user['username']

上述代码中,connect_db()函数创建了一个名为my_database.db的SQLite数据库文件,并返回一个数据库连接对象。query_db()函数封装了对SQLite数据库的查询操作,可以执行任意的SQL查询语句,并返回查询结果。get_user()函数使用query_db()函数查询指定用户的信息,并将结果返回给用户。

三、模板引擎Jinja2

Flask使用Jinja2作为默认的模板引擎,可以方便地进行HTML页面渲染和数据展示。Jinja2是一种灵活的模板引擎,支持模板继承、过滤器和变量等多种扩展功能。

下面是一个使用Jinja2模板引擎的示例:

from flask import render_template

@app.route('/user/:id')
def get_user(id):
    user = query_db('select * from users where id = ?', [id], one=True)
    return render_template('user.html', user=user)

上述代码中,get_user()函数查询指定用户的信息后,使用render_template()函数加载名为user.html的Jinja2模板文件,并将查询结果传递给模板中的user变量,用于页面展示。

user.html模板文件的内容如下:

<html>
<head><title>User Profile</title></head>
<body>
    <h1>{{ user.username }}</h1>
    <p>Email: {{ user.email }}</p>
    <p>Phone: {{ user.phone }}</p>
</body>
</html>

上述代码中,使用了Jinja2模板引擎中的变量和标签,通过{{ user.username }}将用户的用户名展示在页面上,并使用<p>标签将用户的其他信息展示在页面上。