目录
简介
json
方法
对象序列化
反序列化
pickle
可以被打包/解包的对象
常量
方法
序列化
反序列化
安全
参考
序列化
json.
dump
(obj, fp, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)
Python |
JSON |
---|---|
dict |
object |
list, tuple |
array |
str |
string |
int, float, int 和 float 派生的枚举 |
number |
True |
true |
False |
false |
None |
null |
nan
、inf
和 -inf
)进行序列化时会引发一个ValueError。如果 allow_nan 是 true,则使用它们的 JavaScript 等价形式(NaN
、Infinity
和 -Infinity
)。""
,则只会添加换行符。None``(默认值)选择最紧凑的表达。使用一个正整数会让每一层缩进同样数量的空格。如果 *indent* 是一个字符串(比如 ``"\t"
),那个字符串会被用于缩进每一层。现允许使用字符串作为 indent 而不再仅仅是整数。(item_separator, key_separator)
元组。当 indent 为 None
时,默认值取 (', ', ': ')
,否则取 (',', ': ')
。为了得到最紧凑的 JSON 表达式,你应该指定其为 (',', ':')
以消除空白字符。现当 indent 不是 None
时,采用 (',', ': ')
作为默认值。False
),那么字典的输出会以键的顺序排序。default()
方法来序列化额外的类型), 通过 cls 关键字参数来指定;否则将使用JSONEncoder。常用的是这个函数:
json.
dumps
(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)
将 obj 序列化为 JSON 格式的str。 其参数的含义与dump中的相同。
>>> adict = {'s':'ss'}
>>> alist = [1,2]
>>> astr = 'lady_killer9'
>>> aint = 9
>>> aflag = True
>>> nothing = None
>>> json.dumps(adict)
'{"s": "ss"}'
>>> json.dumps(alist)
'[1, 2]'
>>> json.dumps(astr)
'"lady_killer9"'
>>> json.dumps(aint)
'9'
>>> json.dumps(aflag)
'true'
>>> json.dumps(nothing)
'null'
json.
load
(fp, *, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
使用下面的转换表将 fp (一个支持 .read()
并包含一个 JSON 文档的文本或二进制文件) 反序列化为一个 Python 对象。
JSON |
Python |
---|---|
object |
dict |
array |
list |
string |
str |
number (int) |
int |
number (real) |
float |
true |
True |
false |
False |
null |
None |
float(num_str)
。可以用于对 JSON 浮点数使用其它数据类型和解析器 (比如decimal.Decimal
)。int(num_str)
。可以用于对 JSON 整数使用其它数据类型和语法分析程序 (比如float)。'-Infinity'
, 'Infinity'
, 'NaN'
。如果遇到无效的 JSON 数字它会被用于抛出异常。 parse_constant 不再调用 'null' , 'true' , 'false' 。cls
指定;否则使用JSONDecoder。额外的关键词参数会通过类的构造函数传递。如果反序列化的数据不是有效 JSON 文档,抛出JSONDecoderError错误。对应dumps,常用的是这个函数:
json.
loads
(s, *, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
使用上面的转换表将 s (一个包含 JSON 文档的str, bytes或bytearray实例) 反序列化为 Python 对象。
load()
中的含义相同,只有 encoding 被忽略和弃用。>>> d = json.dumps(adict)
>>> json.loads(d)
{'s': 'ss'}
>>> type(json.loads(d))
>>> INT = json.dumps(aint)
>>> bb = bytes(INT,encoding='utf-8')
>>> json.loads(bb)
9
pickle应该是序列化 Python 对象时的首选,marshal存在主要是为了支持 Python 的 .pyc
文件.
下列类型可以被打包:
None
、True
和 False
整数、浮点数、复数
str、byte、bytearray
只包含可打包对象的集合,包括 tuple、list、set 和 dict
定义在模块顶层的函数(使用def定义,lambda
函数不可以,因为lambda函数都是同样的名字)
定义在模块顶层的内置函数
定义在模块顶层的类
某些类实例,这些类的__dict__属性值或__getstate()函数的返回值可以被打包。
pickle.
HIGHEST_PROTOCOL
整数,可用的最高协议版本。此值可以作为 protocol 值传递给dump()和dumps()函数,以及Pickler的构造函数。
pickle.
DEFAULT_PROTOCOL
一个整数,表示封存操作使用的协议版本。 它可能小于HIGHEST_PROTOCOL
。当前默认协议版本为 3,它是一个为 Python 3 设计的新协议。
pickle.
dump
(obj, file, protocol=None, *, fix_imports=True)
将打包好的对象 obj 写入已打开的文件对象。它等同于 Pickler(file, protocol).dump(obj)
。
HIGHEST_PROTOCOL
。如果没有指定,这一参数默认值为 DEFAULT_PROTOCOL
。指定一个负数就相当于指定 HIGHEST_PROTOCOL
。常用的是这个函数:
pickle.
dumps
(obj, protocol=None, *, fix_imports=True)
将 obj 打包以后的对象作为bytes类型直接返回,而不是将其写入到文件。
>>> import pickle
>>> pickle.dumps(adict)
b'\x80\x03}q\x00X\x01\x00\x00\x00sq\x01X\x02\x00\x00\x00ssq\x02s.'
>>> pickle.dumps(alist)
b'\x80\x03]q\x00(K\x01K\x02e.'
>>> pickle.dumps(astr)
b'\x80\x03X\x0c\x00\x00\x00lady_killer9q\x00.'
>>> pickle.dumps(aint)
b'\x80\x03K\t.'
>>> pickle.dumps(aflag)
b'\x80\x03\x88.'
>>> pickle.dumps(nothing)
b'\x80\x03N.'
pickle.
load
(file, *, fix_imports=True, encoding="ASCII", errors="strict")
从已打开的文件对象中读取打包后的对象,重建其中特定对象的层次结构并返回。它相当于 Unpickler(file).load()
。
encoding='latin1'
。常用的是这个函数:
pickle.
loads
(data, *, fix_imports=True, encoding="ASCII", errors="strict")
重建并返回一个对象的封存表示形式 data 的对象层级结构。 data 必须为类似字节类型的对象。
>>> b = pickle.dumps(alist)
>>> pickle.loads(b)
[1, 2]
未完待续...,等我找个序列化漏洞例子再来更新。
-------------2021年03月13日更新---------
今天进行了实践,写了个简单例子:网络安全-反序列化漏洞简介、攻击与防御
Python3.7-pickle