常用的内建模块(struct、hashlib、hmac)

本文介绍了struct模块用于数据类型与bytes之间的转换,hashlib模块实现摘要算法如MD5和SHA1,以及如何通过加盐增强密码安全性。同时,探讨了hmac算法在哈希过程中混入密钥的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.struct(bytes和其他二进制数据类型的转换)

  • pack函数可以把任意数据类型转换成bytes

    >表示字节顺序是big-endian,也就是网络序,I表示4字节无符号整数。

    后面的参数个数要和处理指令一致。

  • unpack把bytes转换成相应的数据类型
    根据>IH的说明,后面的bytes依次变为I:4字节无符号整数和H:2字节无符号整数


    下面是我把上边的12345678转换回去出的错误。。出现这种错误的原因是



    一个程序用来检查任意文件是否是位图文件,如果是,打印出图片大小和颜色数

2.hashlib(摘要算法又称哈希算法、散列算法)

它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制的字符串表示)

  • MD5(结果是固定的128 bit字节,通常用一个32位的16进制字符串表示)
  • SHA1(结果是160 bit字节,通常用一个40位的16进制字符串表示)
  • 根据用户输入的口令,计算出存储在数据库中的MD5口令
  • 设计一个验证用户登录的函数,根据用户输入的口令是否正确,返回True或False
  • 由于常用口令的MD5值很容易被计算出来,所以,要确保存储的用户口令不是那些已经被计算出来的常用口令的MD5,这一方法通过对原始口令加一个复杂字符串来实现,俗称“加盐”:
  • 根据用户输入的登录名和口令模拟用户注册,计算更安全的MD5;然后,根据修改后的MD5算法实现用户登录的验证

3.hmac

它通过一个标准算法,在计算哈希的过程中,把key混入计算过程中(Hmac算法针对所有哈希算法都通用)

例如:

准备原始的message , 一个key 。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值