当前位置: 首页 > 知识库问答 >
问题:

管理员在管理员站点中创建员工时随机生成密码

百里胜泫
2023-03-14

我从用户模型中继承了三个用户,即Admin、Employee和Relative。

models.py

config = RawConfigParser()
config.read('config.cfg')

class UserManager( BaseUserManager):
    
    def _create_user(self, PAN_ID, password=None, **extra_fields):
        """
        Creates and saves a User with the given email, date of
        birth and password.
        """
        if not PAN_ID:
            raise ValueError('Users must have a PAN_ID')
        extra_fields['email'] = self.normalize_email(extra_fields["email"])
        user = self.model(PAN_ID=PAN_ID, **extra_fields)

        user.set_password(password)
        user.save(using=self._db)
        return user
    
    def create_user(self, PAN_ID, password=None, **extra_fields):

        extra_fields.setdefault('is_staff', False)
        extra_fields.setdefault('is_superuser', False)
        return self._create_user(PAN_ID, password, **extra_fields)
    
    def create_superuser(self, PAN_ID, password=None, **extra_fields):
        extra_fields.setdefault('is_staff', True)
        extra_fields.setdefault('is_superuser', True)

        if extra_fields.get('is_staff') is not True:
            raise ValueError('Superuser must have is_staff=True.')
        if extra_fields.get('is_superuser') is not True:
            raise ValueError('Superuser must have is_superuser=True.')

        return self._create_user(PAN_ID, password, **extra_fields)


class User(AbstractBaseUser, PermissionsMixin):
        
    PAN_ID = models.CharField(max_length=100, unique=True)
    password = models.CharField(_('password'), max_length=128, null=False, blank=True)
    email = models.EmailField(max_length=100, unique=True, blank=True)
    date_joined = models.DateTimeField(auto_now_add=True)
    name = models.CharField( max_length=60, blank=True)
    address = models.CharField(max_length=70, null=True, blank=True)
    holding = models.CharField(max_length=100, null=True, blank=True)
    
    is_staff = models.BooleanField(
        _('staff status'),
        default=True,
        help_text=_(
            'Designates whether the user can log into this admin site.'),
    )
    is_active = models.BooleanField(
        _('active'),
        default=True,
        help_text=_(
            'Designates whether this user should be treated as active. '
            'Unselect this instead of deleting accounts.'
        ),
    )
    
    objects = UserManager()

    USERNAME_FIELD = "PAN_ID"
    EMAIL_FIELD = "email"
    REQUIRED_FIELDS = ['email', 'name', 'holding']
    

    
class Admin(User):
    pass    
    
    
class Employee(User):
    designation = models.CharField(max_length=89, null=True)
    
    
class Relative(User):
    reference = models.OneToOneField(to=User, on_delete=models.CASCADE, related_name="creator")

管理派克

from django.contrib import admin
from base.models import Admin, Employee, Relative, User
from django import forms
from django.contrib.auth.models import Group
from mass import settings
from django.core.mail import send_mail
from abc import ABC
from django.utils import timezone
from django.dispatch.dispatcher import receiver
from  django.db.models.signals import post_save

@receiver(post_save, sender=Employee)
@receiver(post_save, sender=Relative)
def mail(sender,instance, *args, **kwargs ):
   subject = "Hi"
   message  = f"Your password is {instance.password} " 
   from_email = None
   recipient_list = [instance.email]
   send_mail(subject, message, from_email, recipient_list, fail_silently=False, auth_user=None, auth_password=None, connection=None, html_message=None) 

class RandomPasswordAndEmailMixin:
    def save(self, commit=True):
        if not self.instance.pk:
            instance = super().save(commit=False)
            instance.set_password(User.objects.make_random_password())
            return instance.save()
        else:
            self.cleaned_data.pop("password")
            return super.save(commit)
                
class UserModelForm(forms.ModelForm):
    

    class Meta:
        exclude = ('is_staff', 'is_active', 'password')
        
        
class EmployeeModelForm(RandomPasswordAndEmailMixin, UserModelForm):
    class Meta(UserModelForm.Meta):
        model = Employee
          
@admin.register(Employee)        
class EmployeeModelAdmin(admin.ModelAdmin, RandomPasswordAndEmailMixin):
    form = EmployeeModelForm
    

管理员将是超级用户。管理员将前往管理站点,对员工和亲属执行CRUD。在表单中,我只希望管理员输入员工/亲属的用户名(PAN_ID)、密码和电子邮件。单击保存后,应发送邮件的相应信号,并发送电子邮件,以便在邮件功能中访问密码。密码应由make_password自动生成。我得到以下错误。

内部服务器错误:/admin/base/employee/add/Traceback(最近一次调用):文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\core\handlers\exception.py”,第47行,在内部响应=get\u响应(请求)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\core\handlers\base.py”,第179行,在包装返回self中的_get_response response=wrapped_callback(请求,*callback_args,**callback_kwargs)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\contrib\admin\options.py”第614行。管理站。管理员查看(视图)(*args,**kwargs)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\utils\decorators.py”,第130行,在包装的查看响应=view\func(请求,*args,**kwargs)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\views\decorators\cache.py”,第44行,在“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\contrib\admin\sites.py”文件的第233行中,在内部返回视图(请求,*args,**kwargs)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\venv\lib\site packages\django\contrib\admin\options.py”第1653行中,在添加视图中返回self。changeform_view(请求,无,form_url,额外_上下文)文件“C:\Users\Dell\OneDrive\Desktop\Djangdev\venv\lib\site packages\django\utils\decorators.py”,第43行,在_包装返回绑定_方法(*args,**kwargs)文件“C:\Users\Dell\OneDrive\Desktop\Djangdev\venv\lib\site packages\django\utils\decorators.py”,第130行,在changeform\u视图中,在第1534行的"C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\contrib\admin\options.py"文件(请求、*args、**kwargs)中,返回self_更改表单视图(请求、对象id、表单url、额外上下文)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\contrib\admin\options.py”,第1580行,在更改表单视图中。保存模型(请求、新对象、表单、非添加)文件“C:\Users\Dell\OneDrive\Desktop\djangodev\venv\lib\site packages\django\contrib\admin\options.py”,第1093行,保存模型obj。save()AttributeError:'NoneType'对象没有属性'save'[22/Jan/2021 15:13:17]“POST/admin/base/employee/add/HTTP/1.1”500 112227

共有2个答案

李捷
2023-03-14

请尝试将其他子句修改为Super().保存(提交)

澹台景辉
2023-03-14

通过覆盖ModelAdmin子类'save_model方法来解决。文档:Django ModelAdminsave_model。为了使它可重复使用,我只是把它作为一个混合体。

class RandomPasswordAndEmailMixin:
    def save_model(self, request, obj, form, change):
        if not form.instance.pk:
            user = form.save(commit=False) 
            user.set_password(User.objects.make_random_password(20))
            user.save() 
            form.save_m2m()

        super().save_model(request, obj, form, change)

@admin.register(Employee)        
class EmployeeModelAdmin(RandomPasswordAndEmailMixin,admin.ModelAdmin):
    exclude = ('is_staff', 'password')

    
 类似资料:
  • 在您创建的每个项目中,您都可以邀请伙伴加入,成为项目中的一员。项目成员将可以和您一起查看项目的详细测评报告。同时,您也可以在自己拥有的项目中对成员进行管理。目前,管理权限主要为“邀请成员”、“移除成员”和“修改成员”身份。 成员权限 目前,一个项目的成员角色主要为三种:拥有者、管理员和成员,其具体的权限解释如下所示: 拥有者 项目的创建者,拥有“成员管理权”和“项目管理权”。 管理员 由“拥有者”

  • 仅企业版可用 请求header PUT /v1/account/createActManager Authorization:Bearer {ACCESS TOKEN} 注: 请将上方的{ACCESS TOKEN}替换为您的ACCESS TOKEN 请求payload { "username" : "管理员A", "cost_type" : "1", "cost_limi

  • 一、简介 添加和管理管理员。 二、功能演示 1.添加管理员 2,管理管理员 对不需要或过期的管理员进行编辑和删除操作。如下图所示:

  • 一、简介 角色定位了拥有此角色的所有管理员权限,管理员可以为不同的角色成员分配不同的权限配置。 二、功能演示 1.成员管理 对该角色下所有管理员进行管理 2.角色编辑 编辑和添加操作相同,不做详述。 3.口令卡 V9系统集成了口令卡功能,使用户信息更见保密。下面我们做详细介绍。如下图: 点击“申请口令卡”后会提示申请成功.如下图: 注:申请口令卡成功后,请一定妥善保管生成的图片;如丢失,您将不能登

  • 我一直有一个问题与网站管理员工具API。我试图让脚本没有用户交互,并获得我需要的信息。我有谷歌分析与服务帐户,但这是不支持的网站管理员工具。 我目前正在尝试使用API服务器密钥,但当我尝试查询API返回时: 代码403:“用户没有足够的网站权限” 然而,我是我试图查询的网站的所有者。我已经检查了www.google.com/webmasters/tools/home,网站已经验证。 所以我在问我的

  • 成员管理       邀请新成员:点击邀请新成员按钮,复制邀请链接,发给想要邀请的人。如想废弃当前链接,点击“重新生成邀请链接按钮”。 申请加入       访问邀请链接,登录(或注册)中科图像账号,输入验证信息,点击申请,等待审核! 成员申请审核       当有新成员申请时,按钮将显示提醒。点击“新申请”按钮。进入审核界面,为新成员选择对于的角色与分组,点击“审批通过”完成新成员加入。 成员权