当前位置:   article > 正文

【python字符串加密、解密】base64编码简介及相关用法_将raw_str进行base64编码

将raw_str进行base64编码

一、base64编码简介

1. 定义
base64:就是使用64个可打印字符来表示二进制数据的方法。
64个字符:
‘ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/’
64个字符按顺序分别对应了十进制数字的0到63,可以理解为上面的字符串的索引。

2. 转换流程
将字符串转换为base64编码流程:首先将文本字符串--------转换为二进制--------然后用64个字符表示二进制数。
字符串转换为二进制的方式:string.encode(编码方式)
其中string表示要转换的字符串,编码方式有:UTF-8、GBK(繁体中文、简体中文)、GB2312(简体中文编码)、UNICODE等。

二、将字符串转换为base64编码

转换代码如下:

import base64


string = "helloworld"
temp_b = string.encode("utf-8")  # 将字符串转换为二进制
content_b = base64.b64encode(temp_b)
print(content_b)
print('*'*50)
str_result = content_b.decode('utf-8')
print(str_result)

#运行结果
b'aGVsbG93b3JsZA=='
**************************************************
aGVsbG93b3JsZA==
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

注意:整数是不能编码的,整数只有进制转换,比如十进制转换为二进制。如下代码:

string = 12
print(string.encode("GB2312"))

# 运行结果
Traceback (most recent call last):
  File "C:\Users\Admin\Desktop\test.py", line 22, in <module>
    print(string.encode("GB2312"))
AttributeError: 'int' object has no attribute 'encode'
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

三、将编码还原为字符串

>>> import base64
>>> str_result = "aGVsbG93b3JsZA=="
>>> my_str = base64.b64decode(str_result).decode("utf-8")
>>> my_str
'helloworld'
  • 1
  • 2
  • 3
  • 4
  • 5

四、编码方式不同对于Base64编码的区别

第一种情况:
待编码的文本字符串是中文,分别使用不同的编码将中文转换为二进制。

  • 使用"GB2312"编码中文转换为二进制后用64字符表示

    import base64
    
    
    string = "您好"
    temp_b = string.encode("GB2312")     # 将字符串编码为二进制
    content_b = base64.b64encode(temp_b)  # 调用方法并传入二进制数
    print(content_b)
    print('*'*50)
    str_result = content_b.decode("GB2312")
    print(str_result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    运行结果

    b'xPq6ww=='
    **************************************************
    xPq6ww==
    
    • 1
    • 2
    • 3
  • 使用UTF-8编码将中文转换为二进制用64字符表示

    import base64
    
    
    string = "您好"
    temp_b = string.encode("UTF-8")    # 将字符串编码为二进制
    content_b = base64.b64encode(temp_b)  # 调用方法并传入二进制数
    print(content_b)
    print('*'*50)
    str_result = content_b.decode("UTF-8")
    print(str_result)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    运行结果

    b'5oKo5aW9'
    **************************************************
    5oKo5aW9
    
    • 1
    • 2
    • 3

第二种情况
待编码的文本字符串是是英文数字,使用不用编码将中文转换为二进制,后在进行base64编码结果是一样的。
代码如下:

import base64


string = "qwert"
temp_b = string.encode("GB2312")    # 将字符串编码为二进制
content_b = base64.b64encode(temp_b)  # 调用方法并传入二进制数
print(content_b)
print('*'*50)
str_result = content_b.decode("GB2312")
print(str_result)

## 运行结果
b'cXdlcnQ='
**************************************************
cXdlcnQ=
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
import base64


string = "qwert"
temp_b = string.encode("UTF-8")    # 将字符串编码为二进制
content_b = base64.b64encode(temp_b)  # 调用方法并传入二进制数
print(content_b)
print('*'*50)
str_result = content_b.decode("UTF-8")
print(str_result)

## 运行结果
b'cXdlcnQ='
**************************************************
cXdlcnQ=
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

以上参考:https://www.cnblogs.com/luguo3000/p/3940197.html
有不足之处,敬请指正。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/177236?site
推荐阅读
相关标签
  

闽ICP备14008679号