這篇文章主要介紹了python中base64加密解密方法,實例分析了base64加密解密的原理、用途與相關使用技巧,需要的朋友可以參考下
本文實例講述了python中base64加密解密方法。分享給大家供大家參考。具體分析如下:
一、base64Base64是一種基于64個可打印字符來表示二進制數據的表示方法。由于2的6次方等于64,所以每6個比特為一個單元,對應某個可打印字符。三個字節有24個比特,對應于4個Base64單元,即3個字節需要用4個可打印字符來表示。它可用來作為電子郵件的傳輸編碼。在Base64中的可打印字符包括字母A-Z、a-z、數字0-9 ,這樣共有62個字符,此外兩個可打印符号在不同的系統中而不同。編碼後的數據比原始數據略長,為原來的4/3。
Base64常用于在通常處理文本數據的場合,表示、傳輸、存儲一些二進制數據(或不可打印的字符串)。包括MIME的email,email via MIME, 在XML中存儲複雜數據.
python中base64加密解密方法實例分析
在郵件中的用途:
在MIME格式的電子郵件中,base64可以用來将binary的字節序列數據編碼成ASCII字符序列構成的文本。使用時,在傳輸編碼方式中指定base64。使用的字符包括大小寫字母各26個,加上10個數字,和加号“ ”,斜杠“/”,一共64個字符,等号“=”用來作為後綴用途。
在URL中的用途:
标準的Base64并不适合直接放在URL裡傳輸,因為URL編碼器會把标準Base64中的“/”和“ ”字符變為形如“%XX”的形式,而這些“%”号在存入數據庫時還需要再進行轉換,因為ANSI SQL中已将“%”号用作通配符。
為解決此問題,可采用一種用于URL的改進Base64編碼,它不在末尾填充'='号,并将标準Base64中的“ ”和“/”分别改成了“*”和“-”,這樣就免去了在URL編解碼和數據庫存儲時所要作的轉換,避免了編碼信息長度在此過程中的增加,并統一了數據庫、表單等處對象标識符的格式。
另有一種用于正則表達式的改進Base64變種,它将“ ”和“/”改成了“!”和“-”,因為“ ”,“*”在正則表達式中都可能具有特殊含義。
二、python中使用1 C:\Python27>python
2 Python 2.7.2 (default, Jun 12 2011, 14:24:46) [MSC v.1500 64 bit
3 (AMD64)] on win32
4 Type "help", "copyright", "credits" or "license" for more
5 information.
6 >>> import base64
7 >>> str = 'haha'
8 >>> base64.b64encode(str)
9 'aGFoYQ=='
>>> base64.b64decode('aGFoYQ==')
'haha'
三、其他的方法,這個比較重要base64.b64encode(s[, altchars])
base64.b64decode(s[, altchars])
altchars為可選的參數,用來替換 和/的一個兩個長度的字符串。
base64.urlsafe_b64encode(s)
base64.urlsafe_b64decode(s)
此方法中用-代替了 ,用_代替了/ ,這樣可以保證編碼後的字符串放在url裡可以正常訪問
base64.b32encode(s)
base64.b32decode(s[, casefold[, map01]])
base64.b16encode(s)
base64.b16decode(s[, casefold])
希望本文所述對大家的Python程序設計有所幫助。
,更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!