Python 什么是flask框架?快速入门

一、Python flask框架

前言

  • 1.Python 面向对象的高级编程语言,以其语法简单、免费开源、免编译扩展性高,同时也可以嵌入到C/C++程序和丰富的第三方库,Python运用到大数据分析、人工智能、web后端等应用场景上。

  • 2.Python 目前主要流行的web框架:flask、Django、Tornado
    img

补充一下,我们前面学习的库都是叫模块,那么框架与库的区别?

1.框架(framework)跟库的功能类似,但是框架在某一领域上功能更加全面。使用框架,会减少开发者重复造轮子,直接调用其类或者函数就可以实现需求的功能。

2.那么,我们本期来学习Python提供的 web 框架之一-flask框架相关方法的学习,Let’s go~

二、flask 框架概述

1.简介

  • 1.falsk框架是一款基于WSGI的轻量级的Web框架,flask犹如耳详的"麻雀虽小,五脏俱全",因此flask具有简单可扩展性的特点.

  • 2.Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后触发Flask框架,开发人员基于Flask框架提供的功能对请求进行相应的处理,并返回给用户,如果要返回给用户复杂的内容时,需要借助jinja2模板来实现对模板的处理,即:将模板和数据进行渲染,将渲染后的字符串返回给用户浏览器。

  • 3.“微”(micro) 并不表示你需要把整个 Web 应用塞进单个 Python 文件(虽然确实可以 ),也不意味着 Flask 在功能上有所欠缺。微框架中的“微”意味着 Flask 旨在保持核心简单而易于扩展。Flask 不会替你做出太多决策——比如使用何种数据库。而那些 Flask 所选择的——比如使用何种模板引擎——则很容易替换。除此之外的一切都由可由你掌握。如此,Flask 可以与您珠联璧合。

2.须知:

默认情况下,Flask 不包含数据库抽象层、表单验证,或是其它任何已有多种库可以胜任的功能。然而,Flask
支持用扩展来给应用添加这些功能,如同是 Flask
本身实现的一样。众多的扩展提供了数据库集成、表单验证、上传处理、各种各样的开放认证技术等功能。Flask
也许是“微小”的,但它已准备好在需求繁杂的生产环境中投入使用

3.flask框架的优势

  • 基于WSGI应用程序,必须使用显式实例化
  • 使用Werkzeug路由系统进行自动排序路由
  • 使用Jinja2模板引擎,快速方便使用模板
  • 使用线程局部变量,实现快速访问weby应用程序
  • 支持异步等待和ASCI(async-first)
  • 衔接单元测试,开发人员快速进行测试检查
  • 自带开发服务器,无需借助其他第三方网络服务

三、flask 安装

1.安装flask

pip3 install falsk

flask快速使用

2.flask执行流程(入门)

1.一旦请求过滤,执行app(),对象()---->触发类的__call__()
2.请求一来,执行aap()—flask类的__call__方法执行
img

from flask import Flask

# 实例化产生一个Flask对象
app=Flask(__name__)

@app.route('/',methods=['GET',])  # 装饰器(路由匹配)
def index():  # 视图函数
    return 'hello world lqz'

if __name__ == '__main__':
    app.run(port=8080)  # 最终调用了run_simple(),并传端口,self

四、登录,显示用户信息案例

1.案例:登录,显示用户信息

1.template返回的html文件必须放在template文件夹里面(默认)

# 也可以自定制
app = Flask(__name__, render_template='a')
main.py
from flask import Flask,render_template,request,redirect,session,url_for
app = Flask(__name__)
app.debug = True
app.secret_key = 'sdfsdfsdfsdf'

USERS = {
   
    1:{
   'name':'张三','age':18,'gender':'男','text':"道路千万条"},
    2:{
   'name':'李四','age':28,'gender':'男','text':"安全第一条"},
    3:{
   'name':'王五','age':18,'gender':'女','text':"行车不规范"},
}

# 转换器(int:nid)类型(参数get单查)
@app.route('/detail/<int:nid>',methods=['GET'])
def detail(nid):
    user = session.get('user_info')
    if not user:
        return redirect('/login')

    # 获取USERS.get(用户传入id)
    info = USERS.get(nid)
    # 返回html页面,USERS用户信息中的id(用户选择查询)
    return render_template('detail.html',info=info)


@app.route('/index',methods=['GET'])
def index():
    user = session.get('user_info')
    if not user:
        # return redirect('/login')  # 没有登录重定向到login
        url = url_for('l1')  # 反向解析,django中severse
        return redirect(url)  # (没登录,就重定向到login)
    return render_template('index.html',user_dict=USERS)  # 返回html页面,USERS信息


@app.route('/login',methods=['GET','POST'],endpoint='l1')  # 路由中写endpoint='li',那么可以在视图层中使用url_for反向解析出来,路由匹配的地址(login)
def login():
    if request.method == "GET":
        return render_template('login.html')
    else:
        # request.query_string
        user = request.form.get('user')  # django中使用request.POST--->flask: request.form
        pwd = request.form.get('pwd')
        if user == 'cxw' and pwd == '123':
            session['user_info'] = user  # 把登录信息放到session中,加密后,以cookie形似,放到浏览器中
            return
  • 15
    点赞
  • 166
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值