• 技术文章 >常见问题 >Python常见问题

    python中如何实现加密

    yangyang2020-04-04 11:39:14原创3816

    1、Python中使用Base64加密:

    Python内置的base64模块可以直接进行base64的编解码

    注意:用于base64编码的,要么是ASCII包含的字符,要么是二进制数据

    1

    2

    3

    4

    5

    6

    7

    8

    9

    # -*- coding:UTF-8 -*-

    __author__ = 'rxz'

    import base64

      

    a = base64.b64encode(b"hello world")

    print(a) #  b'aGVsbG8gd29ybGQ='

      

    b = base64.b64decode(a)

    print(b) # b"hello world"

    2、Python中使用MD5加密

    由于MD5模块在python3中被移除,在python3中使用hashlib模块进行md5操作

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    # -*- coding:UTF-8 -*-

    __author__ = 'rxz'

    import hashlib

      

    # 待加密信息

    str = '中国你好'

      

    # 创建md5对象,

    #md5对象,md5不能反解,但是加密是固定的,就是关系是一一对应,所以有缺陷,可以被对撞出来

    hl = hashlib.md5()

      

    #要对哪个字符串进行加密,就放这里

    # 此处必须声明encode

    # 若写法为hl.update(str)  报错为: Unicode-objects must be encoded before hashing

    hl.update(str.encode(encoding='utf-8'))

      

    print('MD5加密前为 :' + str)

    #hl.hexdigest()) #拿到加密字符串

    print('MD5加密后为 :' + hl.hexdigest())

      

    """

    MD5加密前为 :中国你好

    MD5加密后为 :560a6b11a85d436acfa4bd7f34462f40

    """

      

    hash3 = hashlib.md5(bytes('abd',encoding='utf-8'))

    '''

    如果没有参数,所以md5遵守一个规则,生成同一个对应关系,如果加了参数,

    就是在原先加密的基础上再加密一层,这样的话参数只有自己知道,防止被撞库,

    因为别人永远拿不到这个参数

    '''

    hash3 .update(bytes("admin",encoding = "utf-8"))

    print(hash3.hexdigest()) #9aea3c0a6c51555c1a4d0a5e9b689ded

    3、使用hmac加密

    python中还有一个hmac模块,它对我们创建key和内容再进行处理然后再加密

    该模块加密是先把数据存储到字典中,然后再进行加密,方法与上述方法类似。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    import hmac

      

      

    hm = hmac.new(b'abc')

    hm = hmac.new('中国你好'.encode(encoding='utf-8'),b'bads')

    print(hm.digest())

    print(hm.hexdigest())

      

    """

    b'\xc8;\x0c\x0b\xd42\xc37\xd0X\xbc\xfbf=RP'

    c83b0c0bd432c337d058bcfb663d5250

    """

    注:加密数据时一定要指定数据编码格式。

    4、使用sha1 加密

    SHA1的全称是Secure Hash Algorithm(安全哈希算法) 。SHA1基于MD5,加密后的数据长度更长,

    它对长度小于264的输入,产生长度为160bit的散列值。比MD5多32位。

    因此,比MD5更加安全,但SHA1的运算速度就比MD5要慢了。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    # -*- coding:UTF-8 -*-

    __author__ = 'rxz'

    import hashlib

      

    str = "中国你好"

    a = hashlib.sha1(str.encode("utf-8")).hexdigest()

    print("sha1加密前为 :",str)

    print("sha1加密前后 :",a)

      

    """

    sha1加密前为 : 中国你好

    sha1加密前后 : 3e6c570876775d0031dbf66247ed1054d4ef695e

    """

    推荐学习《Python教程》。

    专题推荐:python
    上一篇:python中如何清空数组(列表)元素 下一篇:python删掉数据表几列的方法

    相关文章推荐

    • Python文件如何转换为字符串• 如何用Python爬取网页数据

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网