http.cookies — HTTP state management

http.cookies模块定义了一系列类来抽象cookies这个概念,一个HTTP状态管理机制。该模块支持string-only的简单cookies,也支持任意序列化数据类型(serializable data-type)作为cookie的value.

该模块允许下列字符集都可以作为有效字符来表示Cookie name(as key):字符集,string.ascii_lettersstring.digits and !#$%&'*+-.^_`|~ : 。

当遇到无效cookie时,调用CookieError。

exception http.cookies.CookieError

class http.cookies.BaseCookie([input]):该类是一个类似字典的对象(keys为字符串,values为 Morsel 实例)。一旦将一个value赋予给一个key,value就会被说先转换成包含key和value的Morsel。

class http.cookies.SimpleCookie([input]):继承自BaseCookie类,并重写了str(),将value_decode()和value_encode()重写成一致。

1.1 Cookie Objects

BaseCookie.value_decode(val):返回一个字符串的解码值,返回值可以为任何类型。它没啥用,就是为重写而生的(This method does nothing in BaseCookie — it exists so it can be overridden.)

BaseCookie.value_encode(val):返回一个编码值,val可以为任何类型,但返回的必须是string。作用同上。

BaseCookie.output(attrs=Noneheader='Set-Cookie:'sep='\r\n'):返回一个适合作为HTTP头部发送的字符串表示,attrs和header被发送至各自Morsel的output()方法,sep用于连接头部默认为'\r\n'(CRLF)

BaseCookie.js_output(attrs=None):返回一个嵌入式JavaScript片段。

BaseCookie.load(rawdata):若rawdata为一个字符串,将其作为一个HTTP_COOKIE解析并从那里将values作为Morsel添加。若rawdata为一个字典,就等价于:

for k, v in rawdata.items():
cookie[k] = v

1.2 Morsel Objects

class http.cookies.Morsel

Mosels是一种类似字典的对象,它的key集是固定不变的(不区分大小写,默认值为' '.),有:

  • expires
  • path
  • comment
  • domain
  • max-age
  • secure
  • version
  • httponly

Morsel.value:cookie的值

Morsel.coded_value:cookie的编码值(用于网络传送)

Morsel.key:cookie的名

Morsel.set(keyvaluecoded_value):设置key、value和coded_value。

Morsel.isReservedKey(K):K是否是Morsel的key集合中的成员。

Morsel.output(attrs=Noneheader='Set-Cookie:'):返回一个适合作为头部发送的Mosel的字符串表示。头部应为默认的“Set-Cookie:”

Morsel.js_output(attrs=None):返回一个嵌入式JS片段

Morsel.OutputString(attrs=None):返回一个表示Mosel的字符串

Morsel.update(values):values是一个字典,更新对应key的值。key不对raise error。

Morsel.copy(value):返回一个Morsel的浅复制。

Morsel.setdefault(keyvalue=None):key与上述给出的属性不符时raise一个error.

http.cookiejar — Cookie handling for HTTP clients

http.cookiejar模块定义了一系列类用于自动处理HTTP cookies.

需要注意的是,模块urllib.request实现了自动处理cookies(URL opening with automatic cookie handling.)。

该模块定义的异常:

exception http.cookiejar.LoadError

当从一个文件中加载cookies失败时,FileCookieJar的实例就会raise该异常。LoadError是OSError的一个子类。

该模块提供了下列类:

class http.cookiejar.CookieJar(policy=None):policy是指向CookiePolicy接口的一个对象。

  CookieJar类存储了HTTPcookies.它可以从requests里面提取cookies,也可以通过respenses返回cookies.

  CookieJar的实例必要情况下会自动终止包含的cookies。其子类也是负责从文件或数据库中存储和检索cookies。

class http.cookiejar.FileCookieJar(filenamedelayload=Nonepolicy=None):policy是指向CookiePolicy接口的一个对象。

     Cookies are NOT loaded from the named file until either the load() or revert() method is called

class http.cookiejar.CookiePolicy:该类决定是否从服务器接收cookies或向服务器提交cookies

class http.cookiejar.DefaultCookiePolicy(blocked_domains=Noneallowed_domains=Nonenetscape=Truerfc2965=Falserfc2109_as_netscape=Nonehide_cookie2=Falsestrict_domain=Falsestrict_rfc2965_unverifiable=Truestrict_ns_unverifiable=Falsestrict_ns_domain=DefaultCookiePolicy.DomainLiberalstrict_ns_set_initial_dollar=Falsestrict_ns_set_path=False)

class http.cookiejar.Cookie:该类表示Netscape、RFC2109和RFC2965定义的cookies。

1. CookieJar and FileCookieJar Objects

2. FileCookieJar subclasses and co-operation with web browsers

3.CookiePolicy Objects

4. DefaultCookiePolicy Objects

5. Cookie Objects

Module http.cookiejar

  HTTP cookie handling for web clients. The http.cookiejar and http.cookies modules do not depend on each other.

《The Python Standard Library》——http模块阅读笔记3的更多相关文章

  1. Python Standard Library

    Python Standard Library "We'd like to pretend that 'Fredrik' is a role, but even hundreds of vo ...

  2. Python 日期时间处理模块学习笔记

    来自:标点符的<Python 日期时间处理模块学习笔记> Python的时间处理模块在日常的使用中用的不是非常的多,但是使用的时候基本上都是要查资料,还是有些麻烦的,梳理下,便于以后方便的 ...

  3. Python语言中对于json数据的编解码——Usage of json a Python standard library

    一.概述 1.1 关于JSON数据格式 JSON (JavaScript Object Notation), specified by RFC 7159 (which obsoletes RFC 46 ...

  4. The Python Standard Library

    The Python Standard Library¶ While The Python Language Reference describes the exact syntax and sema ...

  5. 《The Python Standard Library》——http模块阅读笔记1

    官方文档:https://docs.python.org/3.5/library/http.html 偷个懒,截图如下: 即,http客户端编程一般用urllib.request库(主要用于“在这复杂 ...

  6. 《The Python Standard Library》——http模块阅读笔记2

    http.server是用来构建HTTP服务器(web服务器)的模块,定义了许多相关的类. 创建及运行服务器的代码一般为: def run(server_class=HTTPServer, handl ...

  7. python os os.path模块学习笔记

    #!/usr/bin/env python #coding=utf-8 import os #创建目录 os.mkdir(r'C:\Users\Silence\Desktop\python') #删除 ...

  8. Python Standard Library 学习(一) -- Built-in Functions 内建函数

    内建函数列表 Built-in Functions abs() divmod() input() open() staticmethod() all() enumerate() int() ord() ...

  9. Python内置模块和第三方模块

    1.Python内置模块和第三方模块 内置模块: Python中,安装好了Python后,本身就带有的库,就叫做Python的内置的库. 内置模块,也被称为Python的标准库. Python 2.x ...

随机推荐

  1. Spring MVC @RequestMapping浅析

    简介:@RequestMappingRequestMapping是一个用来处理请求地址映射的注解,可用于类或方法上.用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径.RequestMapp ...

  2. 杂谈之界面设计和UI测试 (一)

    界面设计,是设计师的工作,UI测试,是测试人员的工作,UI测试究竟是测什么的?界面的排版布局?还是界面文字的书写错误?如果是排版布局,那么设计师该不会傻到设计一个看起来很不友好的界面,坐等测试人员发现 ...

  3. asp.net WebAPI 问题 iisnode默认不支持PUT和DELETE的解决

    因为iisnode的自动重启服务器方便,一直用的它来作为开发中的node服务器,今天一个delete命令过去,得到一个405(?好像是)错误,让我很郁闷. 用原生的node试一下,是完美支持的,本来打 ...

  4. [LintCode笔记了解一下]64.合并排序数组

    Given two sorted integer arrays A and B, merge B into A as one sorted array. 思路: 因为A的后面的部分都是空的留出来给我们 ...

  5. mybatis所需pom文件内容以及配置文件

    官方网站http://www.mybatis.org/mybatis-3/zh/index.htmlpom文件<?xml version="1.0" encoding=&qu ...

  6. 我眼中的SAML (Security Assertion Markup Language)

    提到SAML (Security Assertion Markup Language), 很多人都会联想到单点登录SSO.那么Saml到底是什么,它跟sso到底有什么联系?这里给大家分享一下我在读完了 ...

  7. javaScript prototype实例(正则) 自定义日期格式化方法

    一个JS自定义日期格式化方法,包括了不少知识点,以下方法来自jQuery DataTable中文的官方参考 //return (new Date(data)).Format("yyyy-MM ...

  8. “全栈2019”Java第十六章:下划线在数字中的意义

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  9. react-route简明学习

  10. CSS单行超长溢出如何处理?表格某一行某一列超长如何处理?

    表格某一行某一列超长 截取一部分 并增加...效果 增加titile ======================================================== <td t ...