1 HTTP方法分类

1 GET
浏览器告知服务器:只获取页面上的信息并发给我。这是最常用的方法。
2 HEAD
浏览器告诉服务器:欲获取信息,但是只关心消息头 。应用应像处理 GET 请求一样来处理它,但是不分发实际内容。在Flask中你完全无需人工干预
3 POST
浏览器告诉服务器:想在URL上 发布新信息。并且服务器必须确保数据已存储且仅存储一次。这是 HTML 表单通常发送数据到服务器的方法。
4 PUT
类似 POST 但是服务器可能触发了存储过程多次,多次覆盖掉旧值。你可能会问这有什么用,当然这是有原因的。考虑到传输中连接可能会丢失,在 这种 情况下浏览器和服务器之间的系统可能安全地第二次接收请求,而 不破坏其它东西。因为 POST 它只触发一次,所以用 POST 是不可能的。
5 DELETE
删除给定位置的信息。
6 OPTIONS
给客户端提供一个敏捷的途径来弄清这个 URL 支持哪些 HTTP 方法。 从 Flask 0.6 开始,实现了自动处理。

2 访问请求数据request

@app.route('/request/')
def get_http_message():
print('获取完整的请求url',request.url)
print('获取去掉get传参的url',request.base_url)
print('获取主机名部分的url',request.host_url)
print('获取路由地址',request.path)
print('获取请求的方法',request.method) print('获取get传参',request.args['name'])
print('获取get传参',request.args.get('name','该key不存在'))
request.args.getlist(key) #当key值存在相同时 print('获取form表单传递过来的数据',request.form)
print('获取form表单文件上传的数据',request.files)
print('获取请求头信息',request.headers)
print('获取cookie信息',request.cookies)
print('获取传递过来的json',request.json)
return 'request对象' 应用到验证登录界面
from flask import Flask,request @app.route('/login', methods=['POST', 'GET'])
def login():
error = None
if request.method == 'POST':
if valid_login(request.form['username'],
request.form['password']):
return log_the_user_in(request.form['username'])
else:
error = '不合法username/password'
return render_template('login.html', error=error) 当访问form中属性不存在时,会抛出一个特殊的 KeyError 异常,你可以像捕获标准的 KeyError 一样来捕获它,不捕获它会显示一个 HTTP 400 Bad Request 错误页面。 因此可以采用args属性来访问URL中提交的参数
value = request.args.get('name','')
推荐使用该方式访问URL,因为用户可能会修改 URL,向他们展现一个 400 bad request 页面会影响用户体验。

3 文件上传

HTML表单中指定enctype = 'multipart/form-data'属性,已上传的文件存储在内存中或者文件系统的临时位置,可以通过request.files来进行访问,每个上传的文件都会存储在这个字典里.

from flask import request,Flask
@app.route('/upload',methods=['GET','POST']) def upload_file():
if request.method == 'POST':
file = request.files['file_name'] #文件存储是一个字典,采用键值对方式取值
flie.save('/usr/local/file.py') #可以保存到本地文件系统 #如果你要把文件按客户端提供的文件名存储在服务器上,文件名的访问最好采用secure_filename
file.save('/usr/local/file.py'+ secure_filename(file.filename))

4 静态文件URL

一般Web应用会需要静态文件渲染页面,通常是CSS与JavaScript文件.Flask的实现方法是在包中或者模块的所在目录创建一个名为static的文件夹,在应用中通过/static访问.
给静态文件生成url
url_for('static',filename='style.css')
对应文件就存储在static/style.css

5 会话之session与cookie

5.1 cookie之参数设置
cookie常见参数设置:
response.set_cookie(
key, #键
value, #值
max_age,#以秒为单位的cookie存活时间
expires,失效时间需要datetime的对象
path = '/',存储的路径
)
5.2 cookie之三板斧
  • 设置cookie: set_cookie

@app.route('/set_cookie/')
def set_cookie():
response = make_response('设置cookie')
response.set_cookie('name','zhangsan') #不设置存活时间 默认为当期浏览会话结束
response.set_cookie('name','zhangsan',max_age=10) #设置存活时间为None
expires = time.time()+10
response.set_cookie('name','zhangsan',expires=expires) #设置存活时间为时间戳的秒数
return response
  • 获取cookie:request.cookie
@app.route('/get_cookie/')
def get_cookie():
print(request.cookies)
var = request.cookies.get('name','获取不到name的值')
return '获取cookie的值为{}'.format(var)
  • 移除cookie: delete_cookie
@app.route('/del_cookie/')
def del_cookie():
response = make_response('清除cookie')
response.delete_cookie('name') #移除cookie的值
expiraes = time.time()-10
response.set_cookie('name','',expires=expires) #不设置存活时间 默认为当期浏览会话结束
return response
5.3 session之三板斧
  • 设置session
@app.route('/set_session/')
def set_session():
#设置session的持久化
session.permanent = True
#设置session存活时间为10分钟
app.permanent_session_lifetime = timedelta(minutes=10) session['username'] = 'wangwu'
return '设置session'
  • 获取session
#获取session
@app.route('/get_session/')
def get_session():
val = session.get('username','username值不存在')
return '获取的seesion的值为{}'.format(val)
  • 移除session
#移除session
@app.route('/del_session/')
def del_session():
username = session.pop('username')
return '删除了session中{}的值'.format(username)

附:以登录注册作为例子

from flask import Flask, session, redirect, url_for, request

app = Flask(__name__)
@app.route('/login', methods=['GET', 'POST']) @app.route('/')
def index():
#登录用户显示login username
if 'username' in session:
return 'login {}'.format(session['username'])
return '还未登录' def login():
#登录界面
if request.method == 'POST':
session['username'] = request.form['username']
return redirect(url_for('index'))
return 'method is support' @app.route('/logout')
def logout():
#注销退出登录
session.pop('username', None)
return redirect(url_for('index')) app.secret_key = 'a3f:4AD3/3yXR~XHH!jm[s]daLWX/,?RT' if __name__ == '__main__':
app.run()

Flask入门request session cookie(二)的更多相关文章

  1. flask中的session cookie 测试 和 项目中的用户状态保持

    # -*- coding:utf-8 -*- # Author: json_steve from flask import Flask, current_app, make_response, req ...

  2. Flask入门很轻松 (二)

    转载请在文章开头附上原文链接地址:https://www.cnblogs.com/Sunzz/p/10959454.html 请求钩子 在客户端和服务器交互的过程中,有些准备工作或扫尾工作需要处理,比 ...

  3. 记录:http协议+response+request+session+cookie

    1.http协议 http协议也叫作超文本传输协议,定义了浏览器向怎样向服务器请求资源和服务器怎样将资源传给浏览器.http协议是面向事务的应用层协议,是万维网能够传递资源的可靠保障. 目前http协 ...

  4. flask 入门 之 Python Shell (二)

    创建迁移仓库: 1.安装工具: pip install flask_migarte 2.代码: #encoding:utf-8 from flask_sqlalchemy import SQLAlch ...

  5. Flask 上下文管理-- (session,request,current_app的传递)--类似本地线程实现,以及多app应用

    Flask session,request,current_app的传递 请求上下文的作用 -- 封装请求相关得数据(request,session) 请求上下文 request session re ...

  6. Flask入门系列(转载)

    一.入门系列: Flask入门系列(一)–Hello World 项目开发中,经常要写一些小系统来辅助,比如监控系统,配置系统等等.用传统的Java写,太笨重了,连PHP都嫌麻烦.一直在寻找一个轻量级 ...

  7. 第一篇 Flask基础篇之(配置文件,路由系统,模板,请求响应,session&cookie)

    Flask是一个基于Python开发并且依赖jinja2模板和Werkzeug WSGI服务的一个微型框架,对于Werkzeug本质是Socket服务端,其用于接收http请求并对请求进行预处理,然后 ...

  8. JavaWeb学习记录总结(二十九)--Servlet\Session\Cookie\Filter实现自动登录和记住密码

    一.Servlet package autologin.servlet.login; import java.io.IOException;import java.security.MessageDi ...

  9. Flask框架里的cookie和session

    # -*- encoding: utf-8 -*- #cookie 相关的操作,依赖与make_response库,调用cookie依赖request模块 from flask import Flas ...

随机推荐

  1. 【算法笔记】B1024 科学计数法

    1024 科学计数法 (20 分) 科学计数法是科学家用来表示很大或很小的数字的一种方便的方法,其满足正则表达式 [+-][1-9].[0-9]+E[+-][0-9]+,即数字的整数部分只有 1 位, ...

  2. LeetCode902. Numbers At Most N Given Digit Set

    题目: We have a sorted set of digits D, a non-empty subset of {'1','2','3','4','5','6','7','8','9'}.  ...

  3. P3233 [HNOI2014]世界树

    传送门 看到指定的总节点数小于等于 300000 就知道要搞虚树了 考虑如何在虚树确定每个议事处控制的节点数量 可以两遍dfs 第一遍求儿子对父亲的影响,第二遍求父亲对儿子影响 注意搜索顺序,这样就可 ...

  4. lambda 表达式定制操作

    泛型算法中的定制操作 许多算法都会比较输入序列中的元素以达到排序的效果,通过定制比较操作,可以控制算法按照编程者的意图工作. 普通排序算法: template<class RandomItera ...

  5. 选择IM云服务供应商

    选择IM云服务供应商,其实最重要是有三个因素:费用.技术稳定性.以及后续运维服务. 对于不少创业公司来讲,可能需要找到成本和稳定性的最佳平衡点.目前国内不少IM云服务产品都推出了免费服务项目或者一定期 ...

  6. PIE SDK打开栅格数据

    1. 功能简介 GIS将地理空间数据表示为矢量数据和栅格数据.矢量数据模型使用点.线和多边形来表示具有清晰空间位置和边界的空间要素,如控制点.河流和宗地等,每个要素被赋予一个ID,以便与其属性相关联. ...

  7. 爬虫beautifulsoup实践

    爬虫beautifulsoup实践: 目的:在https://unsplash.com/上爬取图片并保存到本地文件夹里.   一.观察response.首先,在Chrome浏览器里观察一下该网页的re ...

  8. C++ 17的新标准

    几个自己比较关注的C++新标准,说是17的标准,不过估计要拖到20才能真正支持   Module python的import之类的东西   解决问题: include头文件导致速度变慢的问题   目前 ...

  9. 牛客网Java刷题知识点之TCP、UDP、TCP和UDP的区别、socket、TCP编程的客户端一般步骤、TCP编程的服务器端一般步骤、UDP编程的客户端一般步骤、UDP编程的服务器端一般步骤

    福利 => 每天都推送 欢迎大家,关注微信扫码并加入我的4个微信公众号:   大数据躺过的坑      Java从入门到架构师      人工智能躺过的坑         Java全栈大联盟   ...

  10. Kettle集群部署(1台Windows主机和2台Linux服务器)

    不多说,直接上干货! http://blog.csdn.net/jianglushou9763/article/details/70859616