为了确保密码总是在数据库中存储,散列和腌制,我决定使用一个描述符,它会在提供密码时自动散列密码,例如user.password =" jinja125"
这是我的代码
from random import SystemRandom
from backports.pbkdf2 import pbkdf2_hmac, compare_digest
# ...snip...
@password.setter
def password(self, value):
# When a user is first created, give them a salt
if self._salt is None:
self._salt = bytes(SystemRandom().getrandbits(128))
self._password = self._hash_password(value)
然而,当我尝试运行某些测试时,我收到此错误。
File "C:\Users\User\flask-python\site-tracker\app\users\models.py", line 34, in password
self._salt = bytes(random.SystemRandom().getrandbits(simple_bit_counts))
OverflowError: cannot fit 'int' into an index-sized integer
如何才能最好地解决此错误?
答案 0 :(得分:3)
random.getrandbits(k)的 返回带有 k随机位的python long int。
此处k==128
所以1<<128
检查您尝试从(例如)创建bytes
数组的大小值:
>>> random.SystemRandom().getrandbits(128)
135192632488754159854542557748438253357
这对于数组索引而言太大了,更不用说内存了。您可能希望大幅降低您的价值。我想你的意思是2**7
(7位随机)而不是1<<128
现在,如果您想生成128个随机字节,那么您可以这样做:
>>> bytes(random.randrange(0,255) for _ in range(128))
b'\xc9\x8fC\t\xe0\xc8\x8a5\xe4\xafb\xb5c.\x91\xea\x9aqUL\x11\x8d\xe4\xe3W\x87\xecM\xf8K\xa8\xf8\xbb\xb5 \x14H\xda\x1d]L\x13[n*\x87W\xd8\x90v\xfd\x8cQ\xdcY\xe4^\x95h8\xdc\'\x8e\xcb:\xea\xfbF\xf1zh8\xf63\x18WeV\xc6)\xce\xf9*w>\x83e\x0b#"\xf2\x97\xcf\xc2!\xddj\xb2\xbePl\xa2\r\xa7T\x8f\x14\x13\xa4\x1c\xeax\xacMJ2\x88A,\x11\xdev\xe1\xf8\x9b\x12\xd9c'
无需为此致电getrandbits
。正如Amadan所指出的,也许你想要128位,而不是字节,所以改为range(16)
。那么,既然你知道,你可以根据自己的实际需要进行调整。