一 . 什么是CRM
CRM就是客户关系管理系统(customer relationship management)
二 . 用户登录
# models.py文件 class UserProfile(models.Model): username = models.EmailField(max_length=255, unique=True, ) password = models.CharField(verbose_name='密码', max_length=128, ) name = models.CharField('名字', max_length=32) department = models.ForeignKey('Department', default=None, blank=True, null=True, verbose_name='部门') mobile = models.CharField('手机', max_length=32, default=None, blank=True, null=True) memo = models.TextField('备注', blank=True, null=True, default=None) date_joined = models.DateTimeField(auto_now_add=True) is_active = models.BooleanField(default=True) # 管理员看他是否离职,如果离职则改为False,只有账号密码都正确并且is_active=True
可以去网站上扒好看的登录页面
步骤一(找到你想要的模型)
步骤二(查看源代码)
步骤三(找到css样式)
步骤四(在HTML文件中的body部分把路径修改一下)
步骤五(查看效果)
三 . 注册验证
# views.py文件,也可以单独在APP下建议个py文件写 from django import forms from crm import models from django.core.exceptions import ValidationError import hashlib class RegForm(forms.ModelForm): # Meta里面的内容不满足你的验证要求,可以在Meta外面写, password = forms.CharField( widget=forms.PasswordInput, label='密码', min_length=6, max_length=16, # 这个字段的报错信息也只写在这里才生效 error_messages={'min_length': '不能小于6位'} ) re_password = forms.CharField(widget=forms.PasswordInput, label='确认密码', min_length=6, max_length=16) class Meta: # 类名只能是Meta 而且下面的字段名都不能改 model = models.UserProfile # 对应models中的类 fields = '__all__' # 拿到所有的字段 # print(fields) exclude = ['is_active'] # 除了is_active这个字段 labels = { 'username': '用户名' # 前边的那个label改成'用户名' } # 下面的报错信息不会生效,因为在Mata中写的只对默认生成的字段有效 error_messages = { 'required': '不能为空', } # 批量操作, 把所有的字段都加上class=form-control这个属性 def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) for field in self.fields.values(): print(self.fields.values()) # 所有字段对象组成的列表 print('>>>>>', field) # 每个字段对象 field.widget.attrs.update({'class': 'form-control'}) # 全局钩子,常用来验证两次密码输入是否正确 def clean(self): pwd = self.cleaned_data.get('password', '') # 不写空字符串会显示None, None不能encode # print(self.cleaned_data) re_pwd = self.cleaned_data.get('re_password', '') if pwd == re_pwd: # 密码加密 md5 = hashlib.md5() md5.update(pwd.encode('utf-8')) pwd = md5.hexdigest() # 把加密后的密码改写到cleaned_data里面 self.cleaned_data['password'] = pwd return self.cleaned_data self.add_error('re_password', '两次密码不一致') raise ValidationError('两次密码不一致') # 这个全局的错误也必须写
# views.py文件 def register(request): if request.method == 'GET': form_obj = RegForm() return render(request, 'register.html', {'form_obj': form_obj}) else: form_obj = RegForm(request.POST) # 对数据库进行校验 if form_obj.is_valid(): form_obj.save() # 把你提供的数据按照相应的位置插进去,有就插,没有就不插 return HttpResponse('ok') # return redirect('login') return render(request, 'register.html', {'form_obj': form_obj}) # 前端标签中label中for要写form_obj.字段名.id_for_label 这样就可以了