2012-02-28 76 views
51

我已经将一堆用户及其数据导入到django项目中。我需要为每个人分配一个密码。是否有这样的代码用于密码生成,以应对Django哈希和盐?Django密码生成器

+0

它可能已经改变了,但是你不必“应付Django哈希和盐”,因为你可以使用['.set_pass用户对象上的word()'帮助函数](https://docs.djangoproject.com/en/1.10/ref/contrib/auth/#django.contrib.auth.models.User.set_password)处理用你选择的密钥派生函数提供密码,并用它设置'.password'字段/属性。 – 2017-02-01 21:40:58

回答

137

您还可以使用内置的功能make_random_password

for user in new_users: 
    password = User.objects.make_random_password() 
    user.set_password(password) 
    # email/print password 
+11

另请注意,'make_random_password()'接受关键字参数'length'和'allowed_chars'。 – benjaoming 2013-07-17 20:01:20

3
import random 
import string 
user.set_password(''.join([random.choice(string.digits + string.letters) for i in range(0, 10)])) 
user.save() 
4

只需使用API​​ - django.contrib.auth.models.User.set_password()方法。这里有一个例子(我没有测试过,但你应该明白我的意思):

from random import choice 
from string import digits, letters 
from django.contrib.auth.models import User 

def _pw(length=6): 
    s = '' 
    for i in range(length): 
     s += random.choice(digits + letters) 
    return s 

for user in User.objects.all(): # or .filter(...) 
    user.set_password(_pw()) 
    user.save() 
4

您也可以使用from django.utils.crypto import get_random_stringauth模块,它也接受关键字参数lengthallowed_chars

+1

+1。优先于User.objects.make_random_password(),因为它可以从独立脚本运行而不必配置Django设置。我用它来生成随机夹具。 – m000 2016-05-18 13:21:05

3

如果您只需要一个解决方案Django`s,那么下一个尝试:

对于产生正常的密码尝试使用BaseUserManager。

In [341]: from django.contrib.auth.base_user import BaseUserManager 

# simple password, it length is 10, and it contains ascii letters and digits 
In [344]: BaseUserManager().make_random_password() 
Out[344]: 'aYMX5Wk7Cu' 

In [345]: BaseUserManager().make_random_password() 
Out[345]: 'rM7759hw96' 

In [346]: BaseUserManager().make_random_password() 
Out[346]: 'EkbZxEXyAm' 

# passed length of a password 
In [347]: BaseUserManager().make_random_password(45) 
Out[347]: 'dtM9vhSBL9WSFeEdPqj8jVPMH9ytsjPXrkaHUNUQu4zVH' 

In [348]: BaseUserManager().make_random_password(45) 
Out[348]: 'jypVaXuw9Uw8mD4CXtEhtj2E4DVYx23YTMwy8jGTKsreR' 

# passed length of a password and symbols for choice 
In [349]: BaseUserManager().make_random_password(45, 'abcdf') 
Out[349]: 'daacbfabfccfdbdddbbcddcfcfbfcdabbaccbfcadbccd' 

In [351]: import string 

# password contains only digits 
In [352]: BaseUserManager().make_random_password(50, string.digits) 
Out[352]: '00526693878168774026398080457185060971935025500935' 

# password contains only ascii symbols in lowercase 
In [353]: BaseUserManager().make_random_password(50, string.ascii_lowercase) 
Out[353]: 'nvftisuezofnashdhlalfmscnmqtvigwjpfwsyycsefekytmar' 

# password contains only ascii symbols in uppercase 
In [354]: BaseUserManager().make_random_password(50, string.ascii_uppercase) 
Out[354]: 'APKSUHHHTAAJCFEUONIXWWAKJGXIBHTQDZBTSYFTPDFOSRYEQR' 

如果你需要强大和力量的密码,然后尝试内置的 “hashers” 在Django的

In [355]: from django.contrib.auth.hashers import make_password 

In [357]: make_password('') 
Out[357]: 'pbkdf2_sha256$30000$JuKXdW3shCjL$PsPJX7Zale5JUBkWpIJI/+QlsuVWhz9Q+GQWVtTpQ/Y=' 

In [358]: make_password('text') 
Out[358]: 'pbkdf2_sha256$30000$lSv8kQ39BHE7$KQC5hRhuphYBXmBrXZBJGC+nxygfNWTDf8zQf/NNgY8=' 

In [360]: make_password('text', salt=['simething']) 
Out[360]: "pbkdf2_sha256$30000$['simething']$D+1vJQx9W2/c9sIz/J+7iEz4d4KFPg/R+0S87n/RKR4=" 

In [361]: make_password('text', salt=['something']) 
Out[361]: "pbkdf2_sha256$30000$['something']$NIcmOkEyg6mnH5Ljt+KvI2LVgZWg6sXS6Rh865rbhSc=" 

注:

  1. 使用Django的1.10和Python 3.4