1 Flask 和pythonweb框架介绍
| |
| -django:大而全,内置的app多,第三方app也多 |
| -Flask:小而精,没有过多的内置组件,只完成web框架最基本的功能,需要借助于第三方,完成更丰富的功能 |
| -web.py:是一个小巧灵活的Python框架,它简单而且功能强大(国内几乎没有用的) |
| -------异步web框架------ |
| -fastapi:python的异步web框架,不少公司再用,https://fastapi.tiangolo.com/zh/ |
| -sanic:python的异步web框架,供支持异步高并发请求的 web 服务 |
| -tornado:异步框架,用的比较少了 |
| |
| |
| -djagno是同步框架还是异步框架,djagno 3.x以后支持异步 |
| -同步框架的意思:一个线程只处理一个请求 |
| -异步框架的意思:一个线程可以处理多个请求 |
| -异步框架可以很显著的提高并发量 |

1.1 flask介绍
| Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架 |
| -jinja2 模板语法,django的dtl,非常像 |
| -Werkzeug WSGI 符合wsgi协议的web服务器,django使用的是wsgiref |
| |
| |
| |
| |
| from wsgiref.simple_server import make_server |
| |
| |
| def mya(environ, start_response): |
| |
| print(environ) |
| start_response('200 OK', [('Content-Type', 'text/html')]) |
| if environ.get('PATH_INFO') == '/index': |
| with open('index.html','rb') as f: |
| data=f.read() |
| |
| elif environ.get('PATH_INFO') == '/login': |
| with open('login.html', 'rb') as f: |
| data = f.read() |
| else: |
| data=b'<h1>Hello, web!</h1>' |
| return [data] |
| |
| if __name__ == '__main__': |
| myserver = make_server('', 8008, mya) |
| print('监听8010') |
| myserver.serve_forever() |
| |
| |
| from werkzeug.wrappers import Request, Response |
| |
| |
| @Request.application |
| def hello(request): |
| return Response('Hello World!') |
| |
| |
| if __name__ == '__main__': |
| from werkzeug.serving import run_simple |
| |
| run_simple('localhost', 4000, hello) |
2 flask快速使用
| |
| -1.x 没有本质区别 |
| -2.x 没有本质区别,源码上动了,用起来一样 |
| from flask import Flask |
| |
| app = Flask(__name__) |
| |
| |
| |
| |
| |
| |
| @app.route('/index') |
| def index(): |
| return 'hello web' |
| |
| |
| @app.route('/') |
| def home(): |
| return 'hello home' |
| |
| |
| if __name__ == '__main__': |
| |
| app.run() |
| |
3 登录,显示用户信息小案例
3.1 login.html
| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <title>Title</title> |
| </head> |
| <body> |
| |
| <form method="post"> |
| <p>用户名:<input type="text" name="username"></p> |
| <p>密码:<input type="password" name="password"></p> |
| <input type="submit" value="登录"> {{error}} |
| </form> |
| </body> |
| </html> |
3.2 home.html
| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <title>Title</title> |
| </head> |
| <body> |
| <h1>用户列表</h1> |
| <table> |
| {% for k,v in user_dict.items() %} |
| <tr> |
| <td>{{k}}</td> |
| <td>{{v.name}}</td> |
| <td>{{v['name']}}</td> |
| <td>{{v.get('name')}}</td> |
| <td><a href="/detail/{{k}}">查看详细</a></td> |
| </tr> |
| {% endfor %} |
| </table> |
| </body> |
| </html> |
3.3 detail.html
| <!DOCTYPE html> |
| <html lang="en"> |
| <head> |
| <meta charset="UTF-8"> |
| <title>Title</title> |
| </head> |
| <body> |
| <p>名字是:{{user.name}}</p> |
| <p>年龄是:{{user['age']}}</p> |
| <p>性别是:{{user.get('gender')}}</p> |
| <p>{{user.text}}</p> |
| |
| |
| </body> |
| </html> |
3.4 py文件
| from flask import Flask, request, render_template, redirect, session,jsonify |
| |
| app = Flask(__name__) |
| |
| |
| app.secret_key = 'asdfasdfa33aef3aefads' |
| |
| USERS = { |
| 1:{'name':'张三','age':18,'gender':'男','text':"道路千万条"}, |
| 2:{'name':'李四','age':28,'gender':'男','text':"安全第一条"}, |
| 3:{'name':'王五','age':18,'gender':'女','text':"行车不规范"}, |
| } |
| |
| @app.route('/login', methods=['GET', 'POST']) |
| def index(): |
| |
| |
| if request.method == 'GET': |
| return render_template('login.html') |
| else: |
| |
| |
| username = request.form.get('username') |
| password = request.form.get('password') |
| if username == 'lqz' and password == '123': |
| |
| |
| session['name'] = username |
| return redirect('/') |
| else: |
| return render_template('login.html', error='用户名或密码错误') |
| |
| |
| @app.route('/') |
| def home(): |
| |
| if session.get('name'): |
| return render_template('home.html',user_dict=USERS) |
| else: |
| return redirect('/login') |
| |
| |
| @app.route('/detail/<int:pk>') |
| def detail(pk): |
| if session.get('name'): |
| user_detail = USERS.get(pk) |
| return render_template('detail.html', user=user_detail) |
| else: |
| return redirect('/login') |
| |
| |
| @app.route('/test') |
| def test(): |
| return jsonify([{'name':'lqz','age':19}]) |
| if __name__ == '__main__': |
| app.run() |
| |
| |
| |
| ''' |
| # 学到的 |
| 1 注册路由 app.route(路径,methods=[请求方式get,post]) |
| 2 新手四件套: |
| -render_template 渲染模板 跟django有区别 |
| -redirect 重定向 |
| -return 字符串 返回字符串 |
| -jsonify 返回json格式 |
| |
| 3 请求的request对象,是全局的,直接导入使用即可,在不同视图函数中不会混乱 |
| request.method 请求方式 |
| request.form post请求的body体的内容转成了字典 |
| |
| 4 session 全局的,直接导入使用即可,一定要指定秘钥app.secret_key = 'asdfasdfa33aef3aefads' |
| 放值:session['name']='lqz' |
| 取值:session.get('name') |
| |
| 5 模板的渲染 |
| -兼容django的dtl |
| -更强大,可以加括号,字典可以.get .values() .items() |
| -{% for %} |
| |
| 6 转换器@app.route('/detail/<int:pk>') |
| |
| ''' |
4 配置文件方式
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| -DEBUG |
| -SECRET_KEY |
| -SESSION_COOKIE_NAME |
| -PERMANENT_SESSION_LIFETIME |
5 路由系统
5.1 路由本质
| |
| |
| |
| |
| |
| |
| |
| |
| @app.route('/login') |
| def index(): |
| pass |
| |
| |
| |
| |
| -rule是路径 |
| -其他参数都给了options |
| |
| |
| endpoint = options.pop("endpoint", None) |
| |
| |
| |
| self.add_url_rule(rule, endpoint, f, **options) |
| return f |
| |
| |
| def route(self, rule: str, **options: t.Any) -> t.Callable[[T_route], T_route]: |
| def decorator(f: T_route) -> T_route: |
| endpoint = options.pop("endpoint", None) |
| self.add_url_rule(rule, endpoint, f, **options) |
| return f |
| |
| return decorator |
| |
| app.add_url_rule('/', endpoint=None, view_func=home, methods=['GET']) |
| |
| |
| |
| |
5.2 路由参数add_url_rule
| |
| |
| |
| |
| |
| |
| |
| |
| strict_slashes = None |
| ''' |
| @app.route('/index', strict_slashes=False) |
| #访问http://www.xx.com/index/ 或http://www.xx.com/index均可 |
| @app.route('/index', strict_slashes=True) |
| #仅访问http://www.xx.com/index |
| ''' |
| |
| |
| redirect_to = None, |
| ''' |
| @app.route('/index/<int:nid>', redirect_to='/home/<nid>') |
| ''' |
| |
| |
| |
| |
| |
| |
| |
| |
5.3 转换器
| 'default': UnicodeConverter, |
| 'string': UnicodeConverter, |
| 'any': AnyConverter, |
| 'path': PathConverter, |
| 'int': IntegerConverter, |
| 'float': FloatConverter, |
| 'uuid': UUIDConverter, |
| |
本文作者:Python学习之旅
本文链接:https://www.cnblogs.com/yuezongke/p/17666427.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步