Flask--简介

1. flask简介

  • 简介

作者是Armin Ronacher,出生于2010年,本来这个项目只是作者在愚人节的一个玩笑,后来由于非常受欢迎,进而成为一个正式的项目

  • 特点
  • 微框架、简洁、只做他需要做的,给开发者提供了很大的扩展性
  • Flask和相应的插件写得很好,用起来很爽。比如使用SQLAlchemy的ORM操作数据库
  • Flask的灵活度非常之高,他不会帮你做太多的决策,一些你都可以按照自己的意愿进行更改。比如:使用Flask开发数据库的时候,具体是使用SQLAlchemy还是MongoEngine,选择权完全掌握在你自己的手中,区别于Django。把默认的Jinija2模板引擎替换成其他模板引擎都是非常容易的。
  • 官方文档
  • http://www.pythondoc.com/flask/

2. Hello World

  • flask安装
# 激活虚拟环境
cd Virtualenv\flask-env\Scripts
activate

# 安装flask
pip install flask

# 查看版本
1.输入python 
2.输入import flask
3.输入flask.__version__
  • 第一个flask项目
from flask import Flask


# 传入__name__初始化一个Flask应用
app = Flask(__name__)

# 注册路由
@app.route('/')
def index():
    return "Hello World"

if __name__ == '__main__':
	# 启动flask服务
    app.run() 

此时即可在浏览器输入127.0.0.1:5000进行访问。

3. 启动flask服务

  • 3步实现flask服务
# 导入flask包
from flask import Flask

# 通过实例化Flask的方式,实现一个WSGI应用
app = Flask(__name__)

# 通过WSGI协议实现flask应用和服务的的通信,启动一个服务
app.run()   

此时访问127.0.0.1:5000,服务会报404。是因为服务虽然开启了,但是浏览器找不到资源,此时就需要配置路由。

4. Flask实例化参数

通过ctrl + 左键点击Flask类进入源码,内容如下

class Flask(_PackageBoundObject):
    def __init__(
            self,
            import_name,   # 包或者模块的名,但一般都是传递__name__(系统变量,指本py文件的文件名),让flask.helpers.get_root_path函数通过传入的这个名字确定程序的根目录,以便获得静态文件和模板文件的目录
            static_url_path=None,  # 静态文件目录的url路径 默认不写是与static_folder同名,远程静态文件时使用
            static_folder="static", # 静态文件目录的路径 默认当前项目中的static目录
            static_host=None, # 远程静态文件所用的Host地址,默认为空
            host_matching=False,
            subdomain_matching=False,
            template_folder="templates", # template模板目录, 默认当前项目中的 templates 目录
            instance_path=None,  # 指向另一个Flask实例的路径
            instance_relative_config=False,  # 是否加载另一个实例的配置
            root_path=None,  # 主模块所在的目录的绝对路径,默认项目目录
        ):
        pass

5. flask运行方式

  • flask run
# demo.py
app.run()  # 默认(host=127.0.0.1, port=5000, DEBUG=False)
等价于在控制台运行
python  demo.py
  • flask 命令行
export FLASK_APP=demo.py
export FLASK_ENV=development
flask run

终端输入 flask ,即可显示命令参数。

Usage: flask [OPTIONS] COMMAND [ARGS]...

  A general utility script for Flask applications.

  Provides commands from Flask, extensions, and the application. Loads the
  application defined in the FLASK_APP environment variable, or from a
  wsgi.py file. Setting the FLASK_ENV environment variable to 'development'
  will enable debug mode.

    $ export FLASK_APP=hello.py
    $ export FLASK_ENV=development
    $ flask run

Options:
  --version  Show the flask version
  --help     Show this message and exit.

Commands:
  routes  Show the routes for the app.
  run     Run a development server.
  shell   Run a shell in the app context.

终端输入 flask run --help ,即可显示命令参数,如下

Options:
  -h, --host TEXT                 The interface to bind to.
  -p, --port INTEGER              The port to bind to.
  --cert PATH                     Specify a certificate file to use HTTPS.
  --key FILE                      The key file to use when specifying a
                                  certificate.

  --reload / --no-reload          Enable or disable the reloader. By default
                                  the reloader is active if debug is enabled.

  --debugger / --no-debugger      Enable or disable the debugger. By default
                                  the debugger is active if debug is enabled.

  --eager-loading / --lazy-loader
                                  Enable or disable eager loading. By default
                                  eager loading is enabled if the reloader is
                                  disabled.

  --with-threads / --without-threads
                                  Enable or disable multithreading.
  --extra-files PATH              Extra files that trigger a reload on change.
                                  Multiple paths are separated by ':'.

  --help                          Show this message and exit.
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值