1.在一些项目中,接口的报文是通过base64加密传输的,所以在进行接口自动化时,需要对所传的参数进行base64编码,对拿到的响应报文进行解码。
2.Base64编码是一种“防君子不防小人”的编码方式。广泛应用于MIME协议,作为电子邮件的传输编码,生成的编码可逆,后一两位可能有“=”,生成的编码都是ascii字符。
3.优点:速度快,ascii字符,肉眼不可理解。缺点:编码比较长,非常容易被破解,仅适用于加密非关键信息的场合。
4.python3不太一样:因为3.x中字符都为unicode编码,而b64encode函数的参数为byte类型,所以必须先转码。
5.base64 编码方式:会将得到的数据(bytes类型)的每3个字节扩展为4个字节。
6.例如:b'123456'这里就是6个字节。如果输入的字节数多出了1个, 编码后就在末尾加2个"="。如果输入的字节数多出了2个, 编码后就在末尾加1个"="。
# python2中进行Base64编码和解码
import base64,binascii
a1 = "123"
a2 = "1234"
a3 = "12345"
a4 = base64.b64encode(a1)
print a4 # 结果:MTIz
mm = binascii.hexlify(a4)
print mm # 结果:4d54497a
a4 = binascii.unhexlify(mm)
print a4 # 结果:MTIz
a1 = base64.b64decode(a4)
print a1 # 结果:123
a5 = base64.b64encode(a2)
print a5 # 结果:MTIzNA==
a6 = base64.b64encode(a3)
print a6 # 结果:MTIzNDU=
# -*- coding:utf-8 -*-
import base64
a1 = "123"
encodestr = base64.b64encode(a1.encode('utf-8'))
# encodestr = base64.b64encode(a1.encode(encoding='utf-8'))
print(str(encodestr, 'utf-8'))
# 参考:http://www.imooc.com/article/50649
# 参考:https://www.cnblogs.com/zanjiahaoge666/p/7242642.html