欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Python中使用base64模塊來(lái)處理base64編碼的方法

 更新時(shí)間:2016年07月01日 15:53:22   作者:zhaoweikid  
8bit的bytecode經(jīng)常會(huì)被用base64編碼格式保存,Python中自帶base64模塊對(duì)base64提供支持,這里我們就來(lái)詳解Python中使用base64模塊來(lái)處理base64編碼的方法,需要的朋友可以參考下

base64模塊是用來(lái)作base64編碼解碼的。這種編碼方式在電子郵件中是很常見(jiàn)的。
它可以把不能作為文本顯示的二進(jìn)制數(shù)據(jù)編碼為可顯示的文本信息。編碼后的文本大小會(huì)增大1/3。

閑話不說(shuō)了,base64模塊真正用的上的方法只有8個(gè),分別是encode, decode, encodestring, decodestring, b64encode,b64decode, urlsafe_b64decode,urlsafe_b64encode。他們8個(gè)可以兩兩分為4組,encode,decode一組,專門用來(lái)編碼和 解碼文件的,也可以對(duì)StringIO里的數(shù)據(jù)做編解碼;encodestring,decodestring一組,專門用來(lái)編碼和解碼字符串; b64encode和b64decode一組,用來(lái)編碼和解碼字符串,并且有一個(gè)替換符號(hào)字符的功能。這個(gè)功能是這樣的:因?yàn)閎ase64編碼后的字符除 了英文字母和數(shù)字外還有三個(gè)字符 + / =, 其中=只是為了補(bǔ)全編碼后的字符數(shù)為4的整數(shù),而+和/在一些情況下需要被替換的,b64encode和b64decode正是提供了這樣的功能。至于什 么情況下+和/需要被替換,最常見(jiàn)的就是對(duì)url進(jìn)行base64編碼的時(shí)候。urlsafe_b64encode和urlsafe_b64decode 一組,這個(gè)就是用來(lái)專門對(duì)url進(jìn)行base64編解碼的,實(shí)際上也是調(diào)用的前一組函數(shù)。

基本用法
首先準(zhǔn)備一個(gè)64個(gè)字符的數(shù)組[‘A','B','C', … , ‘1', ‘2', … , ‘+']
然后對(duì)二進(jìn)制數(shù)據(jù)進(jìn)行處理, 每三個(gè)字節(jié)(byte)一組, 一共是3x8=24, 劃為4組,每組6bit.這樣我們得到4個(gè)數(shù)字作為索引, 然后查表獲得相應(yīng)的4個(gè)字符, 就是編碼后的字符串.
如果編碼的二進(jìn)制數(shù)不是3的倍數(shù)怎么辦,base64在\x00在末尾不足后,在代碼的末尾添加1~2個(gè)=號(hào),解碼是自動(dòng)去掉

import base64

me = base64.b64encode("mink")
print me            # print 'bWluaw=='

會(huì)把少的字符用=號(hào)補(bǔ)上

print base64.b64decode(me)   # print 'mink'

可以解碼得到原有的字符串

urlsafe_b64encode 和 urlsafe_b64decode

base64的還提供用于url的編碼方法urlsafe_b64encode 和urlsafe_b64decode.

me = base64.urlsafe_b64encode('i\xb7\x1d\xfb\xef\xff')
print me            # print 'abcd--__'

print base64.urlsafe_b64decode(me) print 'abcd++//'

因?yàn)閎ase64編碼后+和-可能會(huì)出現(xiàn)在字符中,所以通過(guò)urlsafe的方法把+轉(zhuǎn)換為-,/轉(zhuǎn)化為_(kāi).

由于=字符也可能出現(xiàn)在Base64編碼中,但=用在URL Cookie里面會(huì)造成歧義,很多Base64編碼后會(huì)把=去掉.去掉=后怎么解碼呢?因?yàn)锽ase64是把3個(gè)字節(jié)變?yōu)?個(gè)字節(jié),所以Base64編碼的長(zhǎng)度永遠(yuǎn)是4的倍數(shù).因此需要加上=把Base64字符串的長(zhǎng)度變?yōu)?的倍數(shù),就可以正常解碼了.

綜合示例

#-*- encoding:gb2312 -*-
import base64
import StringIO

a = "this is a test"
b = base64.encodestring(a) # 對(duì)字符串編碼
print b
print base64.decodestring(b) # 對(duì)字符串解碼

c = StringIO.StringIO()
c.write(a)
d = StringIO.StringIO()
e = StringIO.StringIO()
c.seek(0)
base64.encode(c, d) # 對(duì)StringIO內(nèi)的數(shù)據(jù)進(jìn)行編碼
print d.getvalue()
d.seek(0)
base64.decode(d, e) # 對(duì)StringIO內(nèi)的數(shù)據(jù)進(jìn)行解碼
print e.getvalue()

a = "this is a +test"
b = base64.urlsafe_b64encode(a) # 進(jìn)行url的字符串編碼
print b
print base64.urlsafe_b64decode(b)


上面的encode函數(shù)和decode函數(shù)的參數(shù)其實(shí)還可以是文件對(duì)象的,那的象這樣:

f1 = open('aaa.txt', 'r')
f2 = open('bbb.txt', 'w')

base64.encode(f1, f2)

f1.close()
f2.close()

相關(guān)文章

最新評(píng)論