Python之Base64加解密

欢迎关注【无量测试之道】公众号,回复【领取资源】,
Python编程学习资源干货、
Python+Appium框架APP的UI自动化、
Python+Selenium框架Web的UI自动化、
Python+Unittest框架API自动化、

资源和代码 免费送啦~
文章下方有公众号二维码,可直接微信扫一扫关注即可。

 

1、什么是Base64

Base64是一种基于64个可打印字符来表示二进制数据的表示方法。由于2^6=64,所以每6个比特为一个单元,对应某个可打印字符。

3个字节有24个比特,对应于4个Base64单元,即3个字节可由4个可打印字符来表示。在Base64中的可打印字符包括字母A-Z、a-z、数字0-9,这样共有62个字符,此外两个可打印符号在不同的系统中而不同。

Base64模块真正用得上的方法只有8个,分别是:

encode, decode, encodestring, decodestring, b64encode, b64decode, urlsafe_b64decode, urlsafe_b64encode。
它们8个可以两两分为4组:

encode,decode一组,专门用来编码和解码文件的, 也可以对StringIO里的数据做编解码;

encodestring,decodestring一组,专门用来编码和解码字符串;

b64encode,b64decode一组,用来编码和解码字符串,并且有一个替换符号字符的功能。

这个功能是这样的:因为Base64编码后的字符除了英文字母和数字外还有三个字符' + /  =',其中'='只是为了补全编码后的字符数为4的整数,而'+'和'/'在一些情况下需要被替换的,b64encode和b64decode正是提供了这样的功能。至于什么情况下'+'和'/'需要被替换,最常见的就是对url进行Base64编码的时候。

urlsafe_b64encode,urlsafe_b64decode 一组,这个就是用来专门对url进行Base64编解码的,实际上也是调用的前一组函数。

 

2、Base64有什么使用场景

Base64是一种任意二进制到文本字符串的编码方法,常用于在URL、Cookie、网页中传输少量二进制数据,包括MIME的电子邮件及XML的一些复杂数据。

 

3、base64转换过程

如下图所示:

 

 

 

Python标准库中提供了base64模块,用来进行转换,因使用到以下二组方法,故做如下说明:

base64.b64encode()将bytes类型数据进行base64编码,返回编码后的bytes类型

base64.b64deocde()将base64编码的bytes类型进行解码,返回解码后的bytes类型

decode的作用是将其他编码的字符串转换成unicode编码

encode的作用是将unicode编码转换成其他编码的字符串

 

4、工作中遇到的问题

使用curl 命令可以正常的返回,如下:

tony@l-l-server1.beta.op.tx1 ~ $ curl "http://10.7.37.9:9200/entity-prod-ars_ars-profile/_count?pretty" -u'ars_es_rw:LohZUiU9CIqh1oe4VP'
{
"count" : 61475690,
"_shards" : {
"total" : 5,
"successful" : 5,
"skipped" : 0,
"failed" : 0
}
}

转换为Python的request请求时一直失败。如下图所示:

 

 

 

 正确的处理应该是这样的:

 
def get_es_token():
    username="ars_es_rw"
    password="LohZUiU9CIqh1oe4VP"
    token=base64.b64encode("{}:{}".format(username, password).encode())
    headers = {'content-type': 'application/json',"Authorization":"Basic " + bytes.decode(token)}
    print(headers)
    url="http://10.7.37.9:9200/entity-prod-ars_ars-profile/_count?pretty"
    response = requests.request("POST", url, headers=headers)
    print(response.text)

备注:上面截图失败与下面成功的原因在于要使用bytes.decode方法将token bytes类型转换为str. 或写成:str(token,encoding=’utf8’)都可以。


简单解释下bytes是什么:
bytes 只负责以字节序列的形式(二进制形式)来存储数据,至于这些数据到底表示什么内容(字符串、数字、图片、音频等),完全由程序的解析方式决定。如果采用合适的字符编码方式(字符集),字节串可以恢复成字符串;反之亦然,字符串也可以转换成字节串。


以下是网上查的示例:

 
# bytes object
b = b"example"
# str object
s = "example"
 
# str to bytes
sb = bytes(s, encoding = "utf8")
 
# bytes to str
bs = str(b, encoding = "utf8")
 
# an alternative method
# str to bytes
sb2 = str.encode(s)
 
# bytes to str
bs2 = bytes.decode(b)

5、小技巧

可以看一下在Linux下的加密与解密字符串:

 
tony@l-l-server1.beta.op.tx1 ~ $ echo "ars_es_rw:LohZUiU9CIqh1oe4VP" | base64 
YXJzX2VzX3J3OkxvaFpVaVU5Q0lxaDFvZTRWUAo=
 
tony@l-l-server1.beta.op.tx1 ~ $ echo "YXJzX2VzX3J3OkxvaFpVaVU5Q0lxaDFvZTRWUA==" | base64 -d
ars_es_rw:LohZUiU9CIqh1oe4VP

备注:我的个人公众号已正式开通,致力于测试技术的分享,包含:大数据测试、功能测试,测试开发,API接口自动化、测试运维、UI自动化测试等,微信搜索公众号:“无量测试之道”,或扫描下方二维码:

 添加关注,一起共同成长吧。

posted on 2020-07-07 15:50  Wu_Candy  阅读(535)  评论(0编辑  收藏  举报