先上第一次的代码:
import base64
# 字典文件路径
dic_file_path = 'C:/Users/muzi/Downloads/271_b790fbaa9f8480532fff81553e908114d783bc30/10_million_password_list_top_100.txt'
with open(dic_file_path, 'r') as f:
password_dic = f.readlines()
username = "admin" # 用户名
for password in password_dic:
encodestr = base64.b64encode("admin:" + password.strip())
print(encodestr)
以上是我做题时第一次的base64编码:但在编译的时候遇到了错误

后来我搜索了一下,问题出在了Python3对base的编码问题中:
python3.x与Python2不一样,字符都为unicode编码,而b64encode函数的参数为byte类型,所以必须先转码。
修改后:
import base64
# 字典文件路径
dic_file_path = 'C:/Users/muzi/Downloads/271_b790fbaa9f8480532fff81553e908114d783bc30/10_million_password_list_top_100.txt'
with open(dic_file_path, 'r') as f:
password_dic = f.readlines()
username = "admin" # 用户名
for password in password_dic:
encodestr = base64.b64encode(("admin:" + password.strip()).encode('utf-8'))
print(encodestr)
结果为:

b’ '代表byte的意思。我们只要再将byte转换回去就可以。
print(str(encodestr,'utf-8'))
本文介绍了一个关于在Python3中使用base64进行编码的问题及解决方法。问题源于Python3对字符串的默认处理方式,即所有字符串都是unicode编码,而b64encode函数需要的是byte类型的输入。文章提供了修改前后的代码对比,展示了如何通过encode('utf-8')将字符串转换为byte类型,从而正确地进行base64编码。
3044

被折叠的 条评论
为什么被折叠?



