我的编程空间,编程开发者的网络收藏夹
学习永远不晚

web开发框架Flask学习一

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

web开发框架Flask学习一

flask框架
    用Python做Web开发的三大框架特点
        Django
            主要特点是大而全,集成了很多的组件,例如:Admin Form Model等,不管你用不用的到,他都会为
            你提供,通常用于大型Web应用,由于内部组件足够强大,所以使用Django可以做到一气呵成,
           Django的优点是大而全,缺点也就露出来,这么多的资源一次性全部加载,肯定会造成cpu资源的浪费
        
        flask
            flask原生组件几乎为零,只有底层的jinja2(模板)和Werkzeug(服务器),属于短小精悍型框架,
            flask通常用于小型应用和快速构建应用,其强大的第三方库足以支持一个大型项目

        Tornado
            主要特点是原生异步非阻塞,在IO密集型和多任务处理上占据压倒性的优势,属于专注性框架,通
            常用于API后端应用,游戏服务后台,其内部实现的异步非阻塞真的是很稳,优点是异步,缺点是干净,连个session也不支持
            
    什么是flask的框架
        web访问流程
        web框架
        flask简介    
    创建flask的虚拟环境
        windos下用pycharm创建flask的虚拟环境
        windows下,直接在user目录中创建一个pip目录,如:C:\Users\xx\pip,新建文件pip.ini
        内容如下
             [global]
             index-url = https://pypi.tuna.tsinghua.edu.cn/simple
        利用pycharm的优点自动创建虚拟环境    
        
    写模板程序
        from flask import Flask

        app = Flask(__name__)

        @app.route("/")
        def index():
            return "hello word"

        if __name__ == "__main__":
            app.run(port=9001, debug=True)
        
    Flask参数的配置
        import_name,              #相当于 __name__/"__main__"
        static_path=None,           #静态路径
        static_url_path=None,         #规定了哪种类型的url是静态请求
        static_folder='static',       #如果是静态请求,去static文件夹找文件
        template_folder='templates',    #静态模板,去templates中找模板文件
        instance_path=None,           #论坛 
        instance_relative_config=False   #应用程序的配置
        
    加载配置的方式
        DEBUG = True  设置为调试模式
        app.config.from_object()
            从对象中加载
                class Config(object):
                    DEBUG = True
                app.config.from_object(Config)    
            从配置文件中加载
                从config.ini文件中加载的内容为
                    DEBUG = True
                app.config.from_object("config.ini")
            从环境变量中加载(不推荐使用)
        常用配置的参数 
            app.debug = True
            app.config["DEBUG"] = True
            
    app.run()的三个参数
        host="127.0.0.1"
        port=9001
        debug = True
            
    JSON的数据格式
        json中的数据一定要加双引号("")
        json中的数据实际就是一种在特定格式下显示的字符串
        json中的数据一般是POST请求方式
        json常用的方法
            json.dump()
            json.dumps()   #将字典对象转化为标准格式的json字符串,没有格式化(按照代码中定义的json格式)
            json.load()
            json.loads()    #将json格式的字符串转化为Python对象(字典)
            jsonify()       #将字典对象转化为标准格式的json字符串,格式化显示 
        如果JSON数据中有中文,在浏览器显示是unicode编码,需设置如下:
            #将默认的ASCII编码屏蔽掉,才能在浏览器中显示当前json数据中的具体内容
            app.config["JSON_AS_ASCII"] = False
            
             json_data = {
                "name": "张三",
                "age": 20,
                "gender": "男"
                }
        
    重定向(redirect)
        @app.route("/redirect")
        def func_redirect():
            #跳转到百度等其他网页
            #return redirect("http://www.baidu.com")

            #跳转到当前路径下的某个文件
            return redirect(url_for("要跳转的函数名",是否携带参数))
            
    提供模板文件(render)
        在当前路径中必许有一个文件夹叫templates,其中存放html中的模板代码,否则会有一个
        jinja2.exceptions.TenplatesNotFound的错误
        @app.route("/home")
        def home():
            return render_template("/test.html")  //直接跳转到test.html视图中
        
    自定义状态码
        如何自定义状态码
            @app.route('/login')
            def func():
                return 'login',666  #实际上是一个元祖,犹如 return("login",666)
    
    路由的参数配置
        url中参数的定义
            尖括号(<int:result>)中存放的是转换器和参数,参数的名称以及对参数类型的限制
        请求类型的指定
            默认是GET的请求模式
            app.route("",methods=["GET","POST"])   #app.route()定义规则
            用request.method获取当前请求,查看当前请求是那种请求方式
            
    自定义转换器
        自定义一个类继承BaseConverter
        重写父类的regex变量
        在app.url_map.converters这个字典中增加一组当前所定义的转换器数据(自己定义名字)
        像使用int转换器一样的使用它

     让自定义的转换器能够接收参数
          自定义一个类继承BaseConverter
          用super重写init方法,在init方法中需要有url_map这个参数以及正则表达式的参数*args,这个参数是我们在使用转换器的时候我们自己传递过来的
          在app.url_map.converters这个字典中增加一组当前所定义的转换器数据
          @app.route("/demo/<re(r'a[0-9]{6}'):uname>")
        
      BaseConverter中的其他两个参数的执行时机    
       转换器to_python
              匹配和调用的先后顺序:一定是先匹配,再调用视图函数
              to_python调用的时机:匹配了url之后,在调用视图函数之前
              to_python的作用:用来决定视图函数中的参数的值

          转换器to_url
              to_url是给url_for这个函数使用
              作用:决定url_for 中我们传递的参数,最终的地址栏中所呈现出来的状态
    
    请求错误的处理方式
        主动抛出状态码(abort)
        统一处理错误(@app.errorhandler(404/500/Exception))
    
@app.route("/")
        def index():
            return "hello word"

        @app.route("/login")
        def func_login():
            result = 4/0
            abort(404)
            return "login......"

        @app.route("/register")
        def func_register():
            result = 100 + "111"
            abort(500)
            return "regsit......"

        @app.errorhandler(ZeroDivisionError)
        def errorhandler(e):
            return "除数不能为0"

        @app.errorhandler(TypeError)
        def errorhandler(e):
            return "整型和字符型的数据不能进行运算"

        @app.errorhandler(404)
        def func_browser(e):
            return "浏览器正在更新,请稍等"

        @app.errorhandler(500)
        def func_server(e):
            return "服务器繁忙,请稍后"

        @app.errorhandler(Exception)
        def errorhandler(e):
            return "页面正在加载,请稍后"

        if __name__ == "__main__":
            app.run(port=9001, debug=True)
View Code
    
钩子函数(回调函数) before_first_request 时机: 在开启服务器之后的第一次请求 before_request 时机: 每一个请求之前 使用场景: 对请求统一进行处理,比如黑名单功能 绑定IP地址remote_addr=="192.168.15.60" after_request 时机: 每一次没有报错的请求之后 场景: 统一的对没有报错的响应进行响应头信息增加,如: response.headers["Content-Type"] = "application/json" teardown_request 时机: 每一次请求之后,都会调用 场景: 对错误进行收集 request请求知识 获取请求类型:request.method #获取当前是哪一种请求方式 获取请求的ip地址:request.remote_addr #访问IP地址 获取请求的数据: request.args.get("xxx") #GET请求数据 获取URL中的参数 request.form.get("xxx") #POST请求数据 获取form表单中的数据 request.files.get("xxx") #获取文件数据 list(request.form.keys("name","pwd")) request.values.get("user") #取不到返回None request.values["user"] #直接取用户名 request.values.to_dict() #获取当前表单提交中的所有数据 request.data() #request是基于mimetype进行处理的 request.headers() print(type(request.headers)) """ Host: 127.0.0.1:5000 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2 Accept-Encoding: gzip, deflate Referer: http://127.0.0.1:5000/home Content-Type: application/x-www-form-urlencoded Content-Length: 26 Cookie:csrftoken=vDIozqveCEfArdYXlM6goHVlSQEn7h4bDygNphL2Feas60DiM2di0jlqKfxo7xhA Connection: keep-alive Upgrade-Insecure-Requests: 1 Cache-Control: max-age=0 """ #获取当前的url路径 print(request.path) #/req # 当前url路径的上一级路径 print(request.script_root) # 当前url的全部路径 print(request.url) # http://127.0.0.1:5000/req # 当前url的路径的上一级全部路径 print(request.url_root ) # http://127.0.0.1:5000/ 注意事项 如果url和form中的Key重名的话,form中的同名的key中value会被url中的value覆盖 #http://127.0.0.1:5000/req?id=1&user=20 print(request.values.to_dict()) #{'user': 20 'pwd': 'DragonFire', 'id': '1'} 请求参数携带参数的几种方式 1、http://127.0.0.1/login/zhangan/123456          #直接在地址栏中输入 2、http://127.0.0.1/login?uname=zhangsan&upwd=123456   #利用GET请求 3、http://127.0.0.1/login                 #利用POST请求 uname=zhangsan&upwd=123456 状态的保持 http默认是无状态的,前一个请求和后一个请求之间是独立的,这个是http协议的特性 基于他的这种特性,如果想让不同请求之间可以有关联,需要引入cookie机制 设置cookie cookie是存储在浏览器端的键值字符串,会伴随着浏览器的自求自动提交到服务器,不同的网站不能共享cookie,保存在本地浏览器中安全性较低, 浏览器第一次发起登录请求该网站时,,如果服务器检测到账号和密码正确,就会给该请求设立一个cookie,浏览器会自动把cookie保存起来,
       下一次请求登录时会把该cookie带到服务器,服务器从当前请求中获取当前所使用的cookie,根据cookie就可以判断当前是谁登录
        
from flask import Flask, make_response, request
            app = Flask(__name__)

            # 存储在客户端
            @app.route("/")
            def index():
                user = request.cookies.get("user_name")
                id = request.cookies.get("user_id")
                return "%s---%s"%(user,id)

            @app.route("/login")
            def login():
                response = make_response("success")
                response.set_cookie("user_name", "zhangsan",max_age=3600)
                response.set_cookie("user_id", "2",max_age=3600)
                # return "success"
                return response

            @app.route("/logout")
            def logout():
                response = make_response("success")
                response.delete_cookie("user_name")
                response.delete_cookie("user_id")
                return response

            if __name__ == "__main__":
                app.run(port=9001, debug=True)
View Code
       设置session
            存储在服务器上,对于敏感、重要的信息,建议要存储在服务器端,不能存储在浏览器中,如用户名、余额、等级、验证码等信息在服务器端进行状态保持的方案就是session
            session依赖于cookie
from flask import Flask, session

            app = Flask(__name__)

            app.config["SECRET_KEY"] = "wxb"

            # 存储在服务器上
            @app.route("/")
            def index():
                user_id = session.get("user_id", "")
                user_name = session.get("user_name", "")
                return "%s---%s"%(user_id,user_name)


            @app.route("/login")
            def login():
                session["user_name"] = "lisi"
                session["user_id"] = "1"
                return "success"

            @app.route("/logout")
            def logout():
                session.pop("user_name",None)
                session.pop("user_id",None)
                return "success"

            if __name__ == "__main__":
                app.run(port=9001, debug=True)
View Code

    上下文管理器(类似全局变量)
        请求上下文
            request  当请求发生时,调用视图函数,触发request.get()
            session     
            抛出异常  RuntimeError:working outside of request context
        应用上下文
            current_app     
         current_app.config.get("DEBUG") g变量
         一般作用于跨py文件,先用g.num存取变量,在再另一个py文件中取值 抛出异常
         RuntimeError:working outside of application context flask_script pip install flask_script from flask import Flask flask_script import Manager app = Flask(__name__) manager = Manager(app) @app.route("/") def index(): return "hello world" if __name__ == "__main__": manager.run(debug=True) flask中可以return的几种写法   1)return "字符串"   2)return "字符串",666   3)return redirect("/")   4)response = make_response("字符串") response.set_cookie('username', username) return response 5)return render_template("demo.html",mylist=["haha","hehe"]) 6)response = make_response(render_template("index.html")) response.set_cookie('username', username) return response 7)response = redirect(url_for('transfer')) response.set_cookie('username', username) return response

 

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

web开发框架Flask学习一

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

web开发框架Flask学习一

flask框架 用Python做Web开发的三大框架特点 Django 主要特点是大而全,集成了很多的组件,例如:Admin Form Model等,不管你用不用的到,他都会为
2023-01-30

web开发框架Flask学习二

jinja2模板规范 在当前项目中创建一个文件为templates的文件夹,将其设置为模板文件夹,新建的html为模板页面, 在视图函数中使用render_template(".html的文件", my_list
2023-01-30

《Flask Web开发》学习笔记

前言:想熟练掌握一门web框架,为以后即将诞生的测试工具集做准备。为什么选择flask要做熟练掌握的一门框架,而不是其他的,最主要的原因是可以随意定制。  特别提醒:这本书的代码会提交在github,有基础的人可以直接看github的代码来
2023-01-30

Flask框架的学习指南之开发环境搭建

Flask是一个使用 Python 编写的轻量级 Web 应用框架。其 WSGI 工具箱采用 Werkzeug ,模板引擎则使用 Jinja2。很多功能的实现都参考了django框架。由于项目需要,在此记录下学习的过程及心得。 工欲善其事,
2022-06-04

Python Web开发用Flask还Django框架好

本篇内容主要讲解“Python Web开发用Flask还Django框架好”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python Web开发用Flask还Django框架好”吧!是否有考虑过
2023-06-02

Python怎么使用Web框架Flask开发项目

本篇内容主要讲解“Python怎么使用Web框架Flask开发项目”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python怎么使用Web框架Flask开发项目”吧!一、简介Flask是一个轻量
2023-07-06

Python Web框架Django学习

python web框架Django学习(二)目录: 三、Django创建APP 四、创建登录页面,实现用户交互,后台管理用户(非数据库方式)=================================================
2023-01-31

python web框架学习笔记

一、web框架本质1.基于socket,自己处理请求#!/usr/bin/env python3 #coding:utf8 import socket def handle_request(client):#接收请求buf = client
2022-06-04

我的第一个python web开发框架(

前面ORM模块我们已经完成了开发,接下来要做的就是对项目代码进行重构了。因为对底层数据库操作模块(db_helper.py)进行了改造,之前项目的接口代码全都跑不起来了。  在写ORM模块时,我们已经对产品接口的分页查询、新增、修改、获取指
2023-01-30

Web开发如何学习

这篇文章主要介绍“Web开发如何学习”,在日常操作中,相信很多人在Web开发如何学习问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Web开发如何学习”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!Web开发
2023-06-27

uni-app开发者需要学习Vue框架吗

近年来,随着移动互联网的飞速发展,移动应用开发也逐渐成为了热门的技术领域之一,许多开发者和企业都开发自己的移动应用来提高自身的竞争力。为了满足移动应用的快速迭代和多平台开发的需求,开发者们也积极探索出了一些新的解决方案,其中uni-app就是一个受到广泛应用的跨平台开发框架。那么,uni-app开发者需要学习Vue框架吗?Vue框架是uni-app的基础uni-app是由DCl
2023-05-14

web前端框架开发是啥

Web前端框架,是一种助力Web前端开发的工具,它们在JavaScript编程语言基础之上,往往提供了一些抽象层和约束,以便开发人员能够更加迅速地编写出高质量的Web前端应用。Web前端框架有多种,比如目前最为流行的React、Angular、Vue等等,不同的前端框架都有着各自的优缺点和适用场景。到底什么是Web前端框架开发呢?它主要包括以下几个方面。一、 前端框架的基本组成
2023-05-20

web开发框架之Django基础

在脚本中如何进行Django的运行if __name__ == '__main__': import os import django # 注意路径(当前所在的位置,要加载Django的配置文件) os.enviro
2023-01-30

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录