码迷,mamicode.com
首页 > 编程语言 > 详细

python中base64编码与解码

时间:2017-07-27 01:01:03      阅读:199      评论:0      收藏:0      [点我收藏+]

标签:速度   应用   ascii   int   编码方式   ==   mime   3.x   理解   

引言:

  在一些项目中,接口的报文是通过base64加密传输的,所以在进行接口自动化时,需要对所传的参数进行base64编码,对拿到的响应报文进行解码;

 

Base64编码是一种“防君子不防小人”的编码方式。广泛应用于MIME协议,作为电子邮件的传输编码,生成的编码可逆,后一两位可能有“=”,生成的编码都是ascii字符。
优点:速度快,ascii字符,肉眼不可理解
缺点:编码比较长,非常容易被破解,仅适用于加密非关键信息的场合
python2中进行Base64编码和解码
>>> import base64
>>> s = ‘我是字符串‘
>>> a = base64.b64encode(s)
>>> print a
ztLKx9fWt/u0rg==
>>> print base64.b64decode(a)
我是字符串

python3不太一样:因为3.x中字符都为unicode编码,而b64encode函数的参数为byte类型,所以必须先转码。

import base64

encodestr = base64.b64encode(‘abcr34r344r‘.encode(‘utf-8‘))
print(encodestr)
打印结果为
b‘YWJjcjM0cjM0NHI=‘

结果和我们预想的有点区别,我们只想要获得YWJjcjM0cjM0NHI=,而字符串被b‘‘包围了。
这时肯定有人说了,用正则取出来就好了。。。别急。。。
b 表示 byte的意思,我们只要再将byte转换回去就好了。。。源码如下
import base64

encodestr = base64.b64encode(‘abcr34r344r‘.encode(‘utf-8‘))
print(str(encodestr,‘utf-8‘))
打印结果为
YWJjcjM0cjM0NHI=

python中base64编码与解码

标签:速度   应用   ascii   int   编码方式   ==   mime   3.x   理解   

原文地址:http://www.cnblogs.com/zanjiahaoge666/p/7242642.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!