Flask框架的学习——01—(虚拟环境、管理开发环境、Flask介绍、设置Flask为DEBUG模式、Flask配置文件、URL与视图)

虚拟环境

之前我们的学习,所有的第三方包安装都是直接通过pip install xx的方式进行安装的,这样安装会将那个包安装到你的系统级的Python环境中。但是这样有一个问题,就是如果你现在用Django 1.10.x写了个网站,然后你的领导跟你说,之前有一个旧项目是用Django 0.9开发的,让你来维护,但是Django 1.10不再兼容Django 0.9的一些语法了。这时候就会碰到一个问题,我如何在我的电脑中同时拥有Django 1.10和Django 0.9两套环境呢?这时候我们就可以通过虚拟环境来解决这个问题。

cmd工具中使用pip install xxx是将xxx这个库安装在了全局环境中,而使用pycharm工具的时候,它自带了一个虚拟环境,pip install 是将库安装在了pycharm的虚拟环境中,而且这两个环境不共通。

pipenv

Windows安装pipenv
pip install pipenv

Mac安装
brew install pipenv

Linux安装
pip install pipenv

在这里插入图片描述
在这里插入图片描述
pipfile和pipfile.lock
在这里插入图片描述
在这里插入图片描述

pip国内的一些镜像
  阿里云:  http://mirrors.aliyun.com/pypi/simple/ 
  中国科技大学:  https://pypi.mirrors.ustc.edu.cn/simple/ 
  豆瓣(douban) : http://pypi.douban.com/simple/ 
  清华大学 : https://pypi.tuna.tsinghua.edu.cn/simple/ 
  中国科学技术大学:  http://pypi.mirrors.ustc.edu.cn/simple/

修改源方法:
pip install 库名称 -i 源地址

Pipfile文件
在这里插入图片描述

上面文件的各项代指
url           # 指定国内pip源,不然下载库会很慢

dev-packages  # 开发环境

packages      # 生产环境
django = "*"  # *表示最新版本

requires      # Python版本

pipfile.lock:详细记录环境依赖,并且利用了Hash算法保证了它完整对应关系

进入/退出/删除虚拟环境

pipenv shell    # 进入虚拟环境
exit            # 退出虚拟环境
pipenv --rm     # 删除整个环境  不会删除pipfile

下图是配置虚拟环境安装路径的步骤(默认是在C:\Users\Administrator.virtualenvs)
在这里插入图片描述
上图配置完成之后就可以在Pycharm中进行设置虚拟环境匹配设置
在这里插入图片描述
完成之后代表:前面创建的虚拟环境已经与现在的Pycharm相互匹配
在这里插入图片描述

2、管理开发环境

安装在开发环境下

pipenv install --dev itchat

在虚拟环境中运行命令,使用run参数

pipenv run python manage.py runserver

pipenv有个缺点,lock不稳定而且时间非常长,所以安装包的时候记得加上–skip-lock,最后开发完成要提价到仓库的时候在pipenv lock

pipenv install django --skip-lock

3、Flask简介

flask是一款非常流行的Python Web框架,出生于2010年,作者是Armin Ronacher,后来由于非常受欢迎,进而成为一个正式的项目。

flask自2010年发布第一个版本以来,大受欢迎,深得开发者的喜爱,并且在多个公司已经得到了应用,flask能如此流行的原因,可以分为以下几个特点

  • 微框架、简洁、只做他需要做的,给开发者提供了很大的扩展性。
  • Flask和相应的插件写得很好。
  • 开发效率非常高,比如使用SQLAlchemy的ORM操作数据库可以节省开发者大量书写sql的时间

Flask的灵活度非常之高,他不会帮你做太多的决策,一些你都可以按照自己的意愿进行更改。

  • 使用Flask开发数据库的时候,具体是使用SQLAlchemy还是MongoEngine,选择权完全掌握在你自己的手中。区别于Django,Django内置了非常完善和丰富的功能,并且如果你想替换成你自己想要的,要么不支持,要么非常麻烦。
  • 把默认的Jinija2模板引擎替换成其他模板引擎都是非常容易的。
# 从flask框架中导入Flask类
from flask import Flask

# 传入__name__初始化一个Flask实例
app = Flask(__name__)

# 装饰器
# app.route装饰器映射URL和执行的函数。这个设置将根URL映射到了hello_world函数上
@app.route("/")               # http://127.0.0.1:5000/    根目录
def hello_world():
    return "hello_world"


if __name__ == '__main__':
    app.run()
    
    # 运行本项目,host=0.0.0.0可以让其他电脑也能访问到该网站,port指定访问的端口。默认的host是127.0.0.1,port为5000
    # app.run(host='0.0.0.0', port=9000)  

然后点击运行,在浏览器中输入http://127.0.0.1:5000就能看到hello world了。需要说明一点的是,app.run这种方式只适合于开发,如果在生产环境中,应该使用Gunicorn或者uWSGI来启动。如果是在终端运行的,可以按ctrl+c来让服务停止。

设置Flask为DEBUG模式

默认情况下flask不会开启DEBUG模式,开启DEBUG模式后,flask会在每次保存代码的时候自动的重新载入代码,并且如果代码有错误,会在终端进行提示。
开启DEBUG模式有三种方式

  1. 直接在应用对象上设置
app.debug = True
app.run()
  1. 在执行run方法的时候,传递参数进去
app.run(debug=True)

在这里插入图片描述
上图中的Debug mode: on/Debugger is active!等都说明了Debug模式都已经开启了。
上图中的Debugger PIN是用于在浏览器网页端进行修改错误时候用于验证的。

  1. 在config属性中设置
	# config 配置文件
    app.config.update()
    print(type(app.config))   # <class 'flask.config.Config'>
    print(isinstance(app.config, dict))   # True  说明config类型是dict类型,数据类型中可以使用update方法的就是dict类型
    
    app.config.update(DEBUG=True)
    app.run()

在这里插入图片描述
需要注意的是只能在开发环境下开启DEBUG模式,因为DEBUG模式会带来非常大的安全隐患。

在开启了DEBUG模式后,当程序有异常而进入错误堆栈模式,你第一次点击某个堆栈想查看变量值的时候,页面会弹出一个对话框,让你输入PIN值,这个PIN值在你启动的时候就会出现,比如在刚刚启动的项目中的PIN值为145-623-872,你输入这个值后,Werkzeug会把这个PIN值作为cookie的一部分保存起来,并在8小时候过期,8小时以内不需要再输入PIN值。这样做的目的是为了更加的安全,让调试模式下的攻击者更难攻击到本站。

4、配置文件

Flask项目的配置,都是通过app.config对象来进行配置的。比如要配置一个项目处于DEBUG模式下,那么可以使用app.config['DEBUG] = True来进行设置,那么Flask项目将以DEBUG模式运行。在Flask项目中,有四种方式进行项目的配置

  1. 直接硬编码
app = Flask(__name__)
app.config['DEBUG'] = True
  1. 因为app.config是flask.config.Config的实例,而Config类是继承自dict,因此可以通过update方法
app.config.update(
   DEBUG=True,
   SECRET_KEY='...'
)
  1. 如果你的配置项特别多,你可以把所有的配置项都放在一个模块中,然后通过加载模块的方式进行配置,假设有一个settings.py模块,专门用来存储配置项的,此时你可以通过app.config.from_object()方法进行加载,并且该方法既可以接收模块的的字符串名称,也可以模块对象
# 1. 通过模块字符串
app.config.from_object('settings')
# 2. 通过模块对象
import settings
app.config.from_object(settings)

在这里插入图片描述
4. 也可以通过另外一个方法加载,该方法就是app.config.from_pyfile(),该方法传入一个文件名,通常是以.py结尾的文件,但也不限于只使用.py后缀的文件

app.config.from_pyfile('settings.py',silent=True)

在这里插入图片描述

5、URL与视图

URL与视图
URL与函数的映射

从之前的helloworld.py文件中,我们已经看到,一个URL要与执行函数进行映射,使用的是@app.route装饰器。@app.route装饰器中,可以指定URL的规则来进行更加详细的映射,比如现在要映射一个文章详情的URL,文章详情的URL是/article/id/,id有可能为1、2、3…,那么可以通过以下方式。

# 从flask框架中导入Flask类
from flask import Flask

# 导入flask中的config
# from flask import config

# 导入config.py的文件
import config

# 传入__name__初始化一个Flask实例
app = Flask(__name__)

# 装饰器
# app.route装饰器映射URL和执行的函数。这个设置将根URL映射到了hello_world函数上
@app.route("/")               # http://127.0.0.1:5000/    根目录
def hello_world():
    return "hello_world"


@app.route("/xxx")
def hello_xxx():
    return "hello_xxx"


@app.route("/123")
def hello_123():
    return "hello_world:123"


if __name__ == '__main__':
    app.config.from_pyfile('config.py')
    app.run()

在这里插入图片描述

@app.route("/list/<id>")
def article_list(id):
    return "这是第{}篇文章".format(id)

在这里插入图片描述
其中,尖括号是固定写法,语法为,variable默认的数据类型是字符串。如果需要指定类型,则要写成converter:variable,其中converter就是类型名称,可以有以下几种:

string: 默认的数据类型,接受没有任何斜杠/的字符串。
int: 整形
float: 浮点型。
path: 和string类似,但是可以传递斜杠/。
uuid: uuid类型的字符串。(永远不会重复的字符串)
any:可以指定多种路径
@app.route("/list/<int:id>")    # int:限制数据类型
def article_list(id):
    return "这是第{}篇文章".format(id)


@app.route("/list/<path:id>")    # int:限制数据类型
def article_detail(id):
    return "detail:这是第{}篇文章".format(id)

在这里插入图片描述

# article,blog  不同参数的形式
@app.route('/<any(article,blog):url_path>/')   # 注意最后的 / 符号
def item(url_path):
  return url_path

如果不想定制子路径来传递参数,也可以通过传统的?=的形式来传递参数,例如:/article?id=xxx,这种情况下,可以通过request.args.get(‘id’)来获取id的值。如果是post方法,则可以通过request.form.get(‘id’)来进行获取

from flask import request
@app.route("/wd")
def zzzz():
    return request.args.get("name")

在这里插入图片描述

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值