目录
  • 基础知识
    • 使用框架的优点:
    • flask常用扩展包:
      • 基本格式:
      • 拓展:
      • return
      • 重定向
      • 取网址参数
      • content-type
      • cookie\session
      • flask路由
      • request属性
      • 上下文
      • 注册路由

基础知识

使用框架的优点:

稳定性和可扩展性强
可以降低开发难度,提高了开发效率

flask诞生于2010年,是armin ronacher用python语言基于werkzeug工具箱编写的轻量级web开发框架
flask本身相当于一个内核,其他几乎所有的功能都要用到扩展(邮件扩展flask-mail,用户认证flask-login,数据库flask-sql_alchemy),都需要用第三方的扩展来实现。
其wsgi工具箱采用werkzeug(路由模块),模块引擎则使用jinja2.这两个也是flask框架的核心

flask常用扩展包:

flask-sqlalchemy 操作数据库
flask-script 插入脚本
flask-migrate 管理迁移数据库
flask-session session存储方式指定
flask-wtf 表单
flask-mail 邮件
flask-bable 提供国际化和本地化支持,翻译;
flask-login 认证用户状态;
flask-openid 认证;
flask-restful 开发rest api的工具;
flask-bootstrap 集成前端twitter bootstrap框架
flask-moment 本地化日期和时间
flask-admin 简单而可扩展的管理接口的框架

扩展列表:

1.中文文档()
2.英文文档(http://flask.pocoo.org/docs/0.11/)

基本格式:

from flask import flask
app=flask(__name__)
@app.route('/')
def a():
    return 'aa'
app.run()

打开谷歌 网址为你的ip地址后加上:再加上默认的端口号5000 页面展示为aa

app.run(host='0.0.0.0',port=80,debug=true)

host:设置为’0.0.0.0’时在同一个局域网别的电脑ip都能访问,不设置这个参数时只有自己的ip能访问
port:是默认端口号,为80时,网址后面不用加:你设置的端口号,
debug:在代码中修改return的值后debug的值为true时,不用重新执行程序,刷新网页即可刷新内容

拓展:

from flask import flask
app=flask(__name__)
@app.route('/<orders_id>')    #加个<>  <>里写的内容为参数
def a(orders_id):
    return '%s'%orders_id
app.run()

在谷歌里输入你的ip后加上/你要写的内容 网页展示内容即为你要写的内容
如果限制只能是数字的话 <int:orders_id> <float:orders_id>

return

return 只能返回字符串 和render_template
如果要返回字典之类的 要转成json类型

import json
json.dumps()
from flask import flask,jsonify

return {'a':'b'}  #报错
return str({'a':'b'})  #纯文本形式,没有数据类型,即没有键值对
return json.dumps({'a':'v'})  #文本形式,但保留了键值对
return jsonify({'a':'v'})  #json类型  有键值对

app.conifg['json_as_ascii']=false   #将返回的汉字不以ascii形式返回

app.config.from_pyfile('settings.ini')  # 可以新建settings.ini  在这里写配置 

重定向

from flask import flask,redirect,url_for
app=flask(__name__)
@app.route('/')
def a():
    return 'a'
@app.route('/five')
def five():
    return redirect(url_for('a'))   #当你输入网址为你的ip+/+five 时 这个网页展示内容其实就跳转到a()方法里返回的内容

#重定向到黑马官网
@app.route('/demo5')
def demo5():
    return redirect('http://www.itheima.com')

#重定向到自己写的视图函数
#可以直接填写自己url路径
#也可以使用url_for生成指定视图函数所对应的url

@app.route('/demo1')
def demo1():
    return 'demo1'

#重定向
@app.route('/demo5')
def demo5():
    return redirect(url_for('demo1'))

#重定向到带有参数的视图函数
#在 url_for 函数中传入参数

# 路由传递参数
@app.route('/user/<int:user_id>')
def user_info(user_id):
    return 'hello %d' % user_id

# 重定向
@app.route('/demo5')
def demo5():
    # 使用 url_for 生成指定视图函数所对应的 url
    return redirect(url_for('user_info', user_id=100))



取网址参数

from flask import flask,request,jsonify
app=flask(__name__)
@app.route('/<id>')
def a(id):
    return '%s'%id

#当你输入的网址为你的ip + / + 你要展现的内容,  页面内容即为你要展现的内容

@app.route('/')
def b():
    name=request.args.get('name')
    id=request.args.get('id')
    return jsonify({'name':name,'id':id})

#当你输入的网址为你的ip + /? +name=小明&id=7  展现的内容即为{'name':小明,'id':7}

content-type

json类型: ‘content-type’:’application/json’
字符串类型:’content-type’:’text/plain’
解析类型:’content-type’:’text/html’

cookie\session

获取cookie  request.get.cookie(”)
获取session  session.get(”)

cookie:指某些网站为了辨别用户身份、进行会话跟踪而储存在用户本地的数据(通常经过加密)
复数形式cookies
cookie是由服务器生成,发送给客户端浏览器,浏览器会将cookie的key/value保存,下次请求同一网站时就发送该cookie给服务器(前提是浏览器设置为启用cookie)
cookie的key/value可以由服务器端自己定义

cookie是存储在浏览器中的一段纯文本信息,建议不要存储敏感信息如密码,因为电脑上的浏览器可能被其它人使用
cookie基于域名安全,不同域名的cookie是不能互相访问的
如访问itcast.cn时向浏览器中写了cookie信息,使用同一浏览器访问baidu.com时,无法访问到itcast.cn写的cookie信息
浏览器的同源策略
当浏览器请求某网站时,会将本网站下所有cookie信息提交给服务器,所以在request中可以读取cookie信息

#设置cookie
from flask import flask,response
@app.route('/cookie')
    def set_cookie():
        resp=response("this is to set cookie")
        resp.set_cookie('username','itcast')
        return resp

设置过期时间
@app.route('/cookie')
def set_cookie():
    response=response('hello world')
    response.set_cookie('username','itheima',3600)    #单位是秒
    return response

获取cookie
from flask import flask,request
#获取cookie
@app.route('/request')
def resp_cookie():
    resp=request.cookies.get('username')
    return resp

session
对于敏感重要的信息,建议储存在服务器端,在服务器端进行状态保持的方案就是session
session依赖于cookie
session数据的获取
session:请求上下文对象,用于处理http请求中的一些数据内容
@app.route('/index1')
def index1():
    session['username']='itcast'
    return reddirect(url_for('index'))
@app.route('/')
def index():
    return session.get('username')
记得设置secretz-key='itcast'  这个里面的值自己可以随意设置

删除session
session.pop('')

app.config['permanent_session_lifetime']=20  #设置session的时效



flask路由

指定路由地址
#指定访问路径为demo1
@app.route('/demo')
def demo1():
    return 'demo1'

给路由传参 
有时我们需要将同一类url映射到同一个视图函数处理,比如:使用同一个视图函数来显示不同用户的个人信息

#路由传递参数
@app.route('/user/<user_id>')
def user_info(user_id):
    return 'hello %s'%user_id

输入的网址后缀加的什么 在网页展示的就是什么,下面那个函数括号里必须是上面的参数
路由传递的参数默认当作string处理,也可以指定参数的类型

#路由传递参数
@app.route('user/<int:user_id>')
def user_info(user_id):
    return 'hello %d'%user_id

这里指定int,尖括号中的内容是动态的。在此暂时可以理解为接受int类型的值,实际上int代表使用intergeconverter去处理url传入的参数

指定请求方式
在flask中。定义一个路由,默认的请求方式为:
get
options(自带)
head (自带)

如果像添加请求方式,
@app.route('/demo2',methods=['get','post'])
def demo2():
    #直接从请求中取到请求方式并返回
    return request.method

request属性

request就是flask中代表当前请求的request对象,期中一个请求上下文变量

(理解成全局变量,在视图函数中直接使用可以取到当前本次请求)
属性      说明                  类型

data        记录请求的数据,并转换为字符串     *
form      记录请求中的表单数据          multidict
args        记录请求中的查询参数          multidict
cookies     记录请求中的cookie信息          dict
headers     记录请求中的报文头           environheaders
method      记录请求使用的http方法           get/post
url     记录请求的url地址          string
files       记录请求上传的文件           *
request.form:获取以post方式提交的数据(接收form提交来的数据);
request.querystring:获取地址栏参数(以get方式提交的数据)
request:包含以上两种方式(优先获取get方式提交的数据),它会在querystring、form、servervariable中都搜寻一遍。

requests模块发送请求有data、params两种携带参数的方法。

params在get请求中使用,data在post请求中使用。params是往url后面添加参数,data是指post请求传入的字典或对象

上下文

上下文:相当于一个容器,保存了flask程序运行过程中的一些信息
flask中有两种上下文,请求上下文和应用上下文

请求上下文(request context)
思考:在试图函数中,如何取到当前请求的相关数据?比如:请求地址,请求方式,cookie等等
在flask中,可以直接在视图函数中使用request这个对象进行获取相关数据,而request就是请求上下文的对象,保存了当前本次请求的相关数据,请求上下文对象有:request,session

request:
封装了http请求的内容,针对的是http请求。举例:user=request.args.get(‘user’),获取的是get请求的参数

session:
用来记录请求会话中的信息,针对的是用户信息,举例:session[‘name’]=user.id,可以记录用户信息,还可以通过session.get[‘name’]获取用户信息

应用上下文对象有:current_app , g
current_app
应用程序上下文用于存储应用程序中的变量,可以通过current_app.name打印当前app的名称,也可以在current_app中存储一些变量,例如:
应用的启动脚本是哪个文件,启动时指定了哪些参数
加载了哪些配置文件,导入了哪些配置
连了那个数据库
有哪些public的工具类,常量
应用跑在那个机器上,ip多少,内存多大
current_app.name
current_app.text_value=’value’

g变量
g作为flask程序全局的一个临时变量,充当着中间媒介的作用,我们可以通过它传递一些数据,g保存的是当前请求的全局变量,不同的请求会有不同的全局变量,通过不同的thread id区别

g.name=’abc’
注意:不同的请求,会有不同的全局变量

两者区别:
请求上下文:保存了客户端和服务器交互的数据
应用上下文:flask应用程序运行过程中,保存的一些配置信息,比如程序名、数据库连接、应用信息等
上下文中的对象只能在指定上下文使用,超出范围不能使用, 请求上下文和应用上下文原理实现:

注册路由

@app.route('/')
def hello():
    #会返回status code
    #content-type 在http headers里
    #content-type=text/html  #默认值 当成html格式来解析
    #将返回的结果封装成一个response对象
    headers={
        # 'content-type':'text/plain',  #当成普通的字符串来解析

        'content-type':'application/json'   #返回json类型
    }
    # response=make_response('<html></html>',200)    #301是重定向
    # response.headers=headers
    # return response
    # return '<html></html>'
    return '<html></html>',200,headers

# app.add_url_rule('/hello',view_func=hello)   #也可以这样来注册路由的

以上就是python编程flask框架简单使用教程的详细内容,更多关于python教程flask框架使用的资料请关注www.887551.com其它相关文章!