Python 模擬 Base64編碼

2022-08-02 18:30:19 字數 1203 閱讀 9732

def enbs64(s):

# 編碼後的結果

result = ''

# 二進位制資料

bin_data = ''

# base64編碼對照表

bs64_table = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',

'u', 'v', 'w', 'x', 'y', 'z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',

'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7',

'8', '9', '+', '/']

# 轉為 ascii 再轉為 二進位制

for i in s:

# 8位組成的單個位元組

bytes_8 = bin(ord(i))[2:]

if len(bytes_8) < 8:

# 不夠8位,在前面用0填充

bytes_8 = '0' * (8 - len(bytes_8)) + bytes_8

bin_data += bytes_8

# 在二進位制資料裡,每次取出6個轉為整數,作為下標從bs64編碼表裡取值

for i in range(0, len(bin_data), 6):

# 6位組成的單個位元組

bytes_6 = bin_data[i:i + 6]

# 不足6位,在後面用0填充

if len(bytes_6) < 6:

bytes_6 = bytes_6 + '0' * (6 - len(bytes_6))

index = int(bytes_6, 2)

result += bs64_table[index]

# 全部編碼後,不足4位元組的用 "=" 填充

if len(result) % 4 != 0:

result = result + '=' * (4 - len(result) % 4)

return result

print(enbs64('welcome'))

Base64編碼 Unicode UTF 8編碼

base64編碼 64種可列印字元,表示原二進位制格式中的6bit base64編碼有一張編碼表 解碼的時候也用它 0 63的id對映到可列印字元 6bit 4 8bit 3,所以4個字元一組,表示3個8 bit二進位制子節 原二進位制子節數不為3個倍數時 原位元組缺1個,則編碼為3個字元 第3個字...

base64編碼 動畫演示 Base 64 編碼

base64 是一種十分流行的編碼方式,僅僅使用 64 個字元加等號 就可以以文字的形式表示所有的二進位制資料了,因為它能夠把二進位制格式通過編碼轉換成可見字元,所有我們就可以通過的把二進位制格式比如,檔案等通過 base64 編碼然後通過文字的形式共享出去,是不是很神奇呀。把輸入的資料轉換成 二進...

python迴圈解碼base64

第一次寫部落格,都不知道該如何下手,寫的不是很好,還望各位大佬不要噴我。先來介紹一下base64 base64是網路上最常見的用於傳輸8bit位元組碼的編碼方式之一,base64就是一種基於64個可列印字元來表示二進位制資料的方法。在看了一段時間的python,然後結合網上的指令碼,自己寫了乙個解碼...