• Python Flask框架-开发简单博客-项目布局、应用设置


    作者:Eason_LYC
    悲观者预言失败,十言九中。 乐观者创造奇迹,一次即可。
    一个人的价值,只在于他所拥有的。所以可以不学无术,但不能一无所有!
    技术领域:WEB安全、网络攻防
    关注WEB安全、网络攻防。我的专栏文章知识点全面细致,逻辑清晰、结合实战,让你在学习路上事半功倍,少走弯路!
    个人社区:极乐世界-技术至上
    追求技术至上,这是我们理想中的极乐世界~(关注我即可加入社区)

    本专栏是对Flask官方文档中个人博客搭建进行的归纳总结,与官方文档结合事半功倍。基础薄弱的同学请戳Flask官方文档教程

    本人经验,学习一门语言或框架时,请首先阅读并官方文档。学习完毕后,再看其他相关文章,如本系列文章,才是正确的学习道路。

    如果python都完全不熟悉,一定不要着急学习框架,请首先学习python官方文档,一步一个脚印。要不然从入门到放弃是大概率事件。

    1、本章知识点总结

    请添加图片描述

    2. 项目布局

    2.1 基础信息

    个人博客使用Flask框架2.1.2, 数据库sqlite, 开发软件Pycharm专业版(社区版也可)

    2.2建立文件关系

    一个Flask项目往往是由如下几部分组成

    • 程序核心文件
      • 模板文件(HTML页面)
      • 静态文件(层叠样式表CSS、图片等)
      • 核心逻辑(Flask主程序、数据库文件、接口文件等)
    • 相关配置文件(程序运行配置或相关说明)
    • 环境文件(相关第三方库)
    • 测试文件

    所以我们这个项目的文档结构应该也按此划分
    请添加图片描述

    2.3 环境和第三方库

    没有 venv环境,是由于我使用了本地已存在的环境,相关设置如下
    【参考文章】CMD和Pycharm创建和激活虚拟环境
    请添加图片描述

    3. 应用设置

    3.1 工厂函数作用

    在一个实际应用中,会注册很多路由(蓝图)、插件、工具或模块,如何管理、注册添加?
    在Flask中工厂函数就是解决以上问题的函数,具体作用如下

    • 注册框架
    • 设置SECRET_KEY和数据库实例路径
    • 根据提供的参数启动特定模式,如开发模式、测试模式、生产模式等。
    • 创建数据库实例文件夹
    • 返回框架实例:一个可调用框架对象。
    • 注册路由 — (后续使用)
    • 注册第三方组件 — (后续使用)
    • 添加必要第三方配置 — (后续使用)
    • 也可以将核心逻辑写在这里 — 不推荐

    3.2 代码实现

    这个blog的工厂函数逻辑如下:

    • 引入Flask框架
    • 设置开发模式参数
    • 选择判断启用环境(默认为开发模式,若提供测试模式参数则启动测试模式)
    • 建立实例文件夹(保存数据库的实例)
    • 简单的hello页面
    • 反馈Flask的一个可调用对象(app)

    Flask-project\flaskr\__inti__.py

    import os
    from flask import Flask
    
    
    def create_app(test_config=None):
        """
        工厂函数
        :param test_config: 测试环境配置,默认为空
        :return: 已经被配置好的Flask对象 app
        """
        # 1.引入Flask框架
        app = Flask(__name__, instance_relative_config=True)
    
        # 2.设置SECRET_KEY和数据库实例路径
        app.config.from_mapping(
            SECRET_KEY='dev',
            DATABASE=os.path.join(app.instance_path, 'flaskr.sqlite'),
        )
    
        # 3.根据提供的参数启动特定模式,如开发模式、测试模式、生产模式等。
        if test_config is None:
            app.config.from_pyfile('config.py', silent=True)
        else:
            app.config.from_mapping(test_config)
    
        # 4.创建数据库实例文件夹,没有文件夹则建立,若已存在则报错,但pass
        try:
            os.makedirs(app.instance_path)
        except OSError:
            pass
    
        # 5.创建一个路由,验证工厂函数是否正常
        @app.route('/hello/')
        def hello(name):
            return 'Hello World! by {}'.format(name)
    
        # 6.返回框架实例:一个可调用框架对象
        return app
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    create_app 是一个应用工厂函数,后面的教程中会用到。这个看似简单的函数其实已经做了许多事情。

    1. app = Flask(__name__, instance_relative_config=True) 创建 Flask 实例。

       __name__ 是当前 Python 模块的名称。应用需要知道在哪里设置路 径,使用 __name__ 是一个方便的方法。
      
       instance_relative_config=True 告诉应用配置文件是相对于 instance folder 的相对路径。实例文件 夹在 flaskr 包的外面,用于存放本地数据(例如配置密钥和数据库),不应当提交到版本控制系统。
      
      • 1
      • 2
      • 3
    2. app.config.from_mapping() 设置一个应 用的缺省配置:

         SECRET_KEY 是被 Flask 和扩展用于保证数据安全的。在开发过程中,为了方便可以设置为 'dev' ,但是在发布的时候应当使用一个随机值来重载它。
         DATABASE SQLite 数据库文件存放在路径。它位于 Flask 用于存放实例的 app.instance_path 之内。下一节会更详细地学习数据库的东西。
      
      • 1
      • 2
    3. app.config.from_pyfile()使用 config.py 中的值来重载缺省配置,如果 config.py 存在的话。 例如,当正式部署的时候,用于设置一个正式的 SECRET_KEY 。

      test_config 也会被传递给工厂,并且会替代实例配置。这样可以实现测试和开发的配置分离,相互独立。
      
      • 1
    4. os.makedirs() 可以确保 app.instance_path 存在。 Flask 不会自 动创建实例文件夹,但是必须确保创建这个文件夹,因为 SQLite 数据库文件会被保存在里面。

    5. @app.route() 创建一个简单的路由,这样在继续教 程下面的内容前你可以先看看应用如何运行的。它创建了 URL /hello 和一个函数之间的关联。这个函数会返回一个响应,即一个 ‘Hello, World!’ 字符串。

    4. 运行启动

    4.1 命令行方式启动(根据环境选择使用)

    # CMD
    > set FLASK_APP=flaskr
    > set FLASK_ENV=development
    > flask run
    
    • 1
    • 2
    • 3
    • 4
    # powershell
    > set FLASK_APP=flaskr
    > set FLASK_ENV=development
    > flask run
    
    • 1
    • 2
    • 3
    • 4
    # bash
    $ export FLASK_APP=flaskr
    $ export FLASK_ENV=development
    $ flask run
    
    • 1
    • 2
    • 3
    • 4

    我测试的环境是win10 cmd。启动步骤为
    1. 在cmd中先激活虚拟环境【参考文章】CMD和Pycharm创建和激活虚拟环境
    2. 再切换到项目路径下(Flask-project\)
    3. 输入上述命令行命令(根据你的环境选用)
    4 .浏览器输入urlhttp://127.0.0.1:5000/hello/任意字符
    请添加图片描述

    4.2 Pycharm专业版一键启动方式

    详见截图

    请添加图片描述
    以后每次启动就点击右上角的绿色箭头实现一键启动,十分方便。
    请添加图片描述

    成功,工厂函数完成后,后续文章将继续实现个人博客的各种功能。

  • 相关阅读:
    练习题——【学习补档】库函数的模拟实现
    GateWay实现负载均衡
    R语言countrycode包转换国家名字和代码
    线性表---顺序表示(day1
    【单片机毕业设计】【mcuclub-jk-003】基于单片机的非接触红外测温的设计
    Java源码分析(一)Integer
    Java / MybatisPlus:JSON处理器的应用,在实体对象中设置对象属性,对象嵌套对象
    Gin学习笔记
    kubeadm重新拉取集群的方式
    Gin中间件
  • 原文地址:https://blog.csdn.net/eason612/article/details/127606521