第十一章: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>

相关推荐
AY呀2 小时前
# 从手写 debounce 到企业级实现:我在面试中如何“降维打击”面试官
前端·面试
政采云技术2 小时前
深入理解 setState 执行机制
前端·react.js
清汤饺子2 小时前
Everything Claude Code:让我把 AI 编程效率再翻一倍的东西
前端·javascript·后端
Westward-sun.2 小时前
NLP 词向量实战:PyTorch 从零实现 CBOW(Word2Vec)全流程拆解
人工智能·pytorch·python·深度学习·自然语言处理·word2vec
青瓷程序设计2 小时前
基于YOLO的安全帽佩戴检测系统~Python+模型训练+2026原创+YOLO算法
python·算法·yolo
西洼工作室2 小时前
React TabBar切换与高亮实现
前端·javascript·react.js
belldeep2 小时前
前端:Bootstrap 3.0 , 4.0 , 5.0 有什么差别?
前端·bootstrap·html
badhope2 小时前
2025年3月AI领域纪录:从模型开源到智能体价值重估——风云变幻DLC
人工智能·python·深度学习·计算机视觉·数据挖掘
wuhen_n2 小时前
Tool Schema 设计模式详解
前端·javascript·ai编程