第十一章:Flask入门之从零构建Python Web应用

Flask简介

基于python的web微框架, 只提供了一个稳健的核心, 其他功能全部是通过扩展实现的, 我们只需要学会各项扩展库的使用

Python 虚拟环境

是基于Python基础环境上虚拟出的一个工作环境, 目的是防止基础环境被污染, 便于项目对包的管理

虚拟环境管理方法

复制代码
#### virtualenv
复制代码
#### Virtualenvwrapper
复制代码
#### conda
复制代码
#### pipenv

安装

复制代码
#### `pip install pipenv`
复制代码
#### `pipenv install flask`

第一个应用

python 复制代码
#!/usr/bin/env python
from flask import Flask

# 初始化
app = Flask(__name__)
@app.route('/')
def index():
    return 'Hello World!'

if __name__ == '__main__':
    app.run()

使用

复制代码
#### `python app.py`

路由和视图函数

python 复制代码
#!/usr/bin/env python
from flask import Flask

# 初始化
app = Flask(__name__)
@app.route('/')
def index():
    return 'Hello World!'

@app.route('/a') ## 路由, 指向下面的视图函数
def add(): ## 视图函数
    return '1 + 1 = 2'

# 路由也可以传值
@app.route('/user/<username>')
def user_index(username): ## 在视图函数中指明变量名称
    return 'Hello {}' . format(username)

@app.route('/post/, <int: post_id>')
def show_post(post_id):
    return 'Post {}' . format(post_id)

if __name__ == '__main__':
    app.run(debug=True) ## 随时修改

URL重定向

url_for()

复制代码
#### 构造动态的URL

*

  ##### url_for('函数名', 命名参数, 其它参数)

*

  ```python
  #!/usr/bin/env python
  from flask import Flask
  from flask import url_for
  from flask import redirect

  # 初始化
  app = Flask(__name__)
  @app.route('/')
  def index():
      return 'Hello World!'

  @app.route('/a') ## 路由, 指向下面的视图函数
  def add(): ## 视图函数
      return '1 + 1 = 2'

  # 路由也可以传值
  @app.route('/user/<username>')
  def user_index(username): ## 在视图函数中指明变量名称
      return 'Hello {}' . format(username)

  @app.route('/post/, <int: post_id>')
  def show_post(post_id):
      return 'Post {}' . format(post_id)

  @app.route('/test')
  def test():
      print(url_for('index'))
      print(url_for('user_index', username = 'xxx'))
      print(url_for('show_post', post_id = 1))
      return 'test'

  @app.route('/<username>')
  def hello(username):
      if username == 'handsomexxx':
          return f'Hello {username}'
      else:
          return redirect(url_for('index'))

  if __name__ == '__main__':
      app.run(debug=True) ## 随时修改
  ```

模版渲染

render_template

复制代码
```python
#!/usr/bin/env python
from flask import Flask
from flask import url_for
from flask import redirect
from flask import render_template

# 初始化
app = Flask(__name__)
@app.route('/')
def index():
    return 'Hello World!'

@app.route('/a') ## 路由, 指向下面的视图函数
def add(): ## 视图函数
    return '1 + 1 = 2'

# 路由也可以传值
@app.route('/user/<username>')
def user_index(username): ## 在视图函数中指明变量名称
    return render_template('user_index.html', username = username) ## 模版渲染

@app.route('/post/, <int: post_id>')
def show_post(post_id):
    return 'Post {}' . format(post_id)

@app.route('/test')
def test():
    print(url_for('index'))
    print(url_for('user_index', username = 'xxx'))
    print(url_for('show_post', post_id = 1))
    return 'test'

@app.route('/<username>')
def hello(username):
    if username == 'handsomexxx':
        return f'Hello {username}'
    else:
        return redirect(url_for('index'))

if __name__ == '__main__':
    app.run(debug=True) ## 随时修改
```

```html
<h1> hello, {{ username }}! </h1>
```

get 和 post

GET

python 复制代码
#!/usr/bin/env python
from flask import request
from flask import Flask

# 初始化
app = Flask(__name__)

@app.route('/user/<password>'):
def user_password(password):
    print('User-Agent: ', request.headers.get('User-Agent'))
    print('time: ', request.args.get('time'))
    print('q: ', request.args.get('q'))
    print('issingle: '. request.args.get('issingle'))
    return f'password is {password}'

if __name__ == '__main__':
    app.run(debug=True) ## 随时修改

POST

python 复制代码
#!/usr/bin/env python
from flask import request
from flask import Flask

# 初始化
app = Flask(__name__)

@app.route('/register', method = ['GET', 'POST'])
def register():
    print('method: ', request.method)
    print('name', request.form['name'])
    print('password', request.from.get('password'))
    pritn('hobbies: ', request.form.getlist('hobbies'))
    print('age: ', request.form.get('age', default = 18))
    return 'register successd!'

if __name__ == '__main__':
    app.run(debug=True) ## 随时修改
python 复制代码
#!/usr/bin/env python
import requests

# 设置需要发送的数据
user_info = {'name': 'xxx', 'password': '123', 'hobbies': ['code', 'game', 'run']}

# 向URL发送POST请求
r = requests.post('http://127.0.0.1:5000/register', data = user_info)
print(r.text)

SESSION

python 复制代码
#!/usr/bin/env python
from flask import session   
from flask import Flask

# 初始化
app = Flask(__name__)

# 不使用安全码, 浏览器会报错
app.secret_key = 'adadhjkhajhh'

@app.route('/set_session')
def set_session():
    ## 设置session的持久化
    session.permanent = True
    session['username'] = 'xxx'
    return '成功设置 session'

@app.route('/get_session')
def get_session():
    value = session.get('username')
    return f'成功获取session值为 {value}'

if __name__ == '__main__':
    app.run(debug=True) ## 随时修改
python 复制代码
#!/usr/bin/env python
from flask import Flask
from flask import make_response

# 初始化
app = Flask(__name__)

@app.route('/user/<username>')
def user_index(username): ## 在视图函数中指明变量名称
    if username == 'invalid':
        abort(404)
    return render_template('user_index.html')

# 不使用安全码, 浏览器会报错
app.secret_key = 'adadhjkhajhh'

@app.route('/set_session')
def set_session():
    ## 设置session的持久化
    session.permanent = True
    session['username'] = 'xxx'
    return '成功设置 session'

@app.route('/get_session')
def get_session():
    value = session.get('username')
    return f'成功获取session值为 {value}'

@app.route('set_cookie')
def set_cookie(username):
    resp = make_response(render_template('user_index.html', username = username))
    resp.set_cookie('username', username)
    return resp

@app.route('/get_cookie')
def get_cookie():
    username = request.cookies.get('username')
    return f'Hello {username}' 

#@app.errorhandler(404)
#def not_found(error):
#    return render_template('404.html'), 404

if __name__ == '__main__':
    app.run(debug = True)   
html 复制代码
<h1>error!</h1>

相关推荐
程序员威哥15 小时前
实战!Python爬京东商品评论:从采集到情感分析+词云可视化,新手30分钟跑通
开发语言·爬虫·python·scrapy
Lee川15 小时前
打字机是怎么炼成的:Chat 流式输出深度解析
前端·后端·面试
前端若水15 小时前
过渡(transition)高级:贝塞尔曲线、硬件加速
前端·css·css3
Lee川15 小时前
Token 无感刷新与 Logout:前端安全会话管理实战
前端·后端·react.js
不会敲代码115 小时前
我写了一个 HTML 文件,把 JS 事件循环彻底搞懂了
前端·javascript·面试
风噪15 小时前
centos7 python3.13全套安装(可用于离线复制)
python
写不来代码的草莓熊15 小时前
SVG 图标插件误读 PNG 图片 + Vite 重启缓存失效重新生成 + 浏览器严格渲染
前端
燐妤15 小时前
前端HTML编程3:初识CSS
前端·html5
UXbot15 小时前
独立设计师UI设计工具推荐(2026):支持AI原型生成与代码导出的5款工具全面评价
前端·人工智能·低代码·ui·交互·产品经理·web app
小陈的进阶之路16 小时前
Python系列课(5)——数据容器
windows·python