当前位置:   article > 正文

【Python】base64模块_python base64

python base64

base64模块是用来作base64编码解码,常用于小型数据的传输。编码后的数据是一个字符串,其包括a-z、A-Z、0-9、/、+共64个字符,即可用6个字节表示,写出数值就是0-63.故三个字节编码的话就变成了4个字节,如果数据字节数不是3的倍数,就不能精确地划分6位的块,此时需要在原数据后添加1个或2个零值字节,使其字节数为3的倍数,然后在编码后的字符串后添加1个或2个‘=’,表示零值字节,故事实上总共由65个字符组成。

在Python种,base64是内置的常用的标准模块,我们可以直接通过import导入base64模块直接使用。

import json,base64
​
if __name__ == '__main__':
    # 要编码的数据
    data = {"uname":"Tanch","uid":3}
    # 先转化为bytes类型数据
    data_bytes = json.dumps(data).encode()
    print(type(data_bytes))
    # 编码
    base_data = base64.b64encode(data_bytes)
    print(base_data)# 解码
    string_bytes = b"eyJ1bmFtZSI6ICJUYW5jaCIsICJ1aWQiOiAzfQ=="
    ori_data = base64.b64decode(string_bytes).decode()
    # 字符串
    print(ori_data)
    # 变回原来的字典
    data = json.loads(ori_data)
    print(type(data))
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

打印结果如下:

<class 'bytes'>
b'eyJ1bmFtZSI6ICJUYW5jaCIsICJ1aWQiOiAzfQ=='
{"uname": "Tanch", "uid": 3}
<class 'dict'>
  • 1
  • 2
  • 3
  • 4

base64模块真正用的上的方法只有8个,分别是encode, decode, encodestring, decodestring, b64encode,b64decode, urlsafe_b64decode,urlsafe_b64encode。

他们8个可以两两分为4组,encode,decode一组,专门用来编码和解码文件的,也可以StringIO里的数据做编解码;encodestring,decodestring一组,专门用来编码和解码字符串; b64encode和b64decode一组,用来编码和解码字符串,并且有一个替换符号字符的功能;urlsafe_b64encode和urlsafe_b64decode一组,这个就是用来专门对url进行base64编解码的。

代码实例如下所示:

b64encode和b64decode:对字符串操作

import base64

st = 'hello world!'.encode()#默认以utf8编码
res = base64.b64encode(st)
print(res.decode())#默认以utf8解码
res = base64.b64decode(res)
print(res.decode())#默认以utf8解码
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

输出结果为:

aGVsbG8gd29ybGQh
hello world!
  • 1
  • 2

编码与解码的处理对象是byte,故对原数据要先编码,使原本的str类型变成byte,解码后直接输出来的是byte对象,故要解码成str对象。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/177242
推荐阅读
相关标签
  

闽ICP备14008679号