写了这么多的定制 功能。终于可以定制一下了!
因为是 stark 和 rbac 两个组建。 一起使用。 所以在这里,再记录一下。需要注意的点:

先放出 目录结构:

先从  stark 开始。
使用stark组件,其实就是对, 自己 的 web 业务中的。 表进行增删改查。

首先再  webapp 下面, 增加一个  stark 的py文件:

from django import forms
from django.core.exceptions import ValidationError
from stark.servers.start_v1 import site, StartHandler, SearchGroupRow, get_choice_text, StarkModelForm
from web import models
from web.utils import pwdmd5 class SchoolHandler(StartHandler):
# list_display = ["title", StartHandler.display_edit, StartHandler.display_del]
list_display = ["title"] class DepartmentHandler(StartHandler):
list_display = ["title"] class UserInfoADDModelForm(StarkModelForm):
'''定制用户添加 form。 增加一个 确认密码字段, 并且需要增加验证'''
confirm_password = forms.CharField(label="确认密码") class Meta:
model = models.UserInfo
fields = ["name", "password", "confirm_password", "nickname", "gender", "telephone", "email", "depart", "roles"] def clean_confirm_password(self):
password = self.cleaned_data.get("password")
confirm_password = self.cleaned_data["confirm_password"]
if password and confirm_password:
if password != confirm_password:
raise ValidationError("两次密码输入不一致")
return confirm_password # 验证完成一定要返回,才能添加到 cleaned_data 字典中. 其他地方才能通过cleaned_data获取到 def clean(self):
'''对密码进行加密, 可以在clean 里面来做。'''
password = self.cleaned_data["password"]
self.cleaned_data["password"] = pwdmd5.creatr_md5(password)
return self.cleaned_data class UserInfoEditModelForm(StarkModelForm):
'''定制用户编辑 form。不显示密码字段。'''
class Meta:
model = models.UserInfo
fields = ["name", "nickname", "gender", "telephone", "email", "depart", "roles"] class UserInfoHandler(StartHandler):
list_display = ["name", "nickname", "age", get_choice_text("性别", "gender"), "telephone", "email", "depart", "roles"] def get_model_form_class(self, is_add=False):
if is_add:
return UserInfoADDModelForm
return UserInfoEditModelForm site.register(models.School, SchoolHandler)
site.register(models.Department, DepartmentHandler)
site.register(models.UserInfo, UserInfoHandler)

在这里,因为要使用 rbac 组件。 所以相应的  我的UserInfo 表。 是继承的 Rbac 组件中的UserInfo 表。
所以  rbac 组件中的 userinfo 表。需要一点小小的,调整:

class UserInfo(models.Model):
name = models.CharField(verbose_name='用户名', max_length=32)
password = models.CharField(verbose_name='密码', max_length=64)
email = models.CharField(verbose_name='邮箱', max_length=32)
roles = models.ManyToManyField(verbose_name='拥有的所有角色', to=Role, blank=True, null=True)
# 一定要记住, 如果被继承了! 在别的地方创建关联关系的时候。 会在别的地方找 Role 这张表。
# 但是 别的地方肯定是没有的, 所有 在指定关联表的时候,直接把表对象放进去 to=Role 不要再使用 to="Role"
# 这样在继承的时候, 会连带这Role这张表的内存地址,一起继承过去。 否则,会报错。 说在你的业务中找不到 Role 这张表 class Meta:
# django以后再做数据库迁移的时候, 不再为UserInfo类,创建相关的表以及结构
# 此类 可以当作 "父类", 被其他 model类继承。
abstract = True

ok 这就可以了!

再来看一看定制方面的功能:
需求:  添加用户时, 需要增加一个  确认密码的字段。  而编辑用户时, 密码字段不应该显示。
实现:  自定义两个 form 类。 一个添加,一个删除。

class UserInfoADDModelForm(StarkModelForm):
'''定制用户添加 form。 增加一个 确认密码字段, 并且需要增加验证'''
confirm_password = forms.CharField(label="确认密码") class Meta:
model = models.UserInfo
fields = ["name", "password", "confirm_password", "nickname", "gender", "telephone", "email", "depart", "roles"] def clean_confirm_password(self):
password = self.cleaned_data.get("password")
confirm_password = self.cleaned_data["confirm_password"]
if password and confirm_password:
if password != confirm_password:
raise ValidationError("两次密码输入不一致")
return confirm_password # 验证完成一定要返回,才能添加到 cleaned_data 字典中. 其他地方才能通过cleaned_data获取到 def clean(self):
'''对密码进行加密, 可以在clean 里面来做。'''
password = self.cleaned_data["password"]
self.cleaned_data["password"] = pwdmd5.creatr_md5(password)
return self.cleaned_data

添加的 form 类。 增加confirm_password 字段。   使用 clean_..... 对该密码进行验证。
再全局 钩子clean中, 对密码进行加密。 因为只有前面的验证通过了, 才会走到这里。

加密写的简单:瞎搞:

import hashlib
def creatr_md5(origin):
# ha = hashlib.md5(b"asdasdasdasdasd") # 也可以在这里进行加盐
ha = hashlib.md5() # 也可以在这里进行加盐
ha.update(origin.encode("utf-8"))
return ha.hexdigest()

再来是编辑:

class UserInfoEditModelForm(StarkModelForm):
'''定制用户编辑 form。不显示密码字段。'''
class Meta:
model = models.UserInfo
fields = ["name", "nickname", "gender", "telephone", "email", "depart", "roles"]

只是少显示一个字段, 没啥好说的!

自定制:

class UserInfoHandler(StartHandler):
list_display = ["name", "nickname", "age", get_choice_text("性别", "gender"), "telephone", "email", "depart", "roles"] def get_model_form_class(self, is_add=False):
if is_add:
return UserInfoADDModelForm
return UserInfoEditModelForm

重写StartHandler 基类中的  get_model_form_class()  方法。返回不同的值:
  此方法是,有 add视图函数, 和 rdit 视图函数进行调用的。
再调用时, 传入参数, is_add=Ture  或者  is_add=False  拿到想要的 form 类。 就可以实现了!

list_display 此列表作用于, 展示页面。 传几个字段,就展示几个字段的信息。

其中的函数 get_choice_text("性别", "gender") 是一个使用,闭包完成的,展示 filed对象中, 有 choice 选项的, 让其显示中文的功能。

crm开发之用户ModelForm定制和密码加密的更多相关文章

  1. crm开发之用户重置密码

    重置 密码这这功能. 我是没有在,stark组件中. 内置的.所以需要,自己进行定制.也就只是,在已有的增删改查的基础上,再增加一条url  和相对应的  视图函数. 好的是, 我已经预留了,增加的接 ...

  2. 使用bcrypt进行用户密码加密的简单实现

    Bcrypt百度百科: bcrypt,是一个跨平台的文件加密工具.由它加密的文件可在所有支持的操作系统和处理器上进行转移.它的口令必须是8至56个字符,并将在内部被转化为448位的密钥. 除了对您的数 ...

  3. Django项目:CRM(客户关系管理系统)--45--37PerfectCRM实现King_admin添加用户时密码加密

    #views # ————————02PerfectCRM创建ADMIN页面———————— from django.shortcuts import render # ————————04Perfe ...

  4. iOS:iOS开发中用户密码保存位置

    原文来自简书:http://www.jianshu.com/p/4af3b8179136/comments/1294203 如果要实现自动登录,不必每次打开应用都去登录,我们势必要把密码保存到本地.一 ...

  5. Python开发之用户密码存储

    在各种线上应用中,用户名密码是用户身份认证的关键,它的重要性不言而喻.一方面,作为保护用户敏感数据的钥匙来说,一旦被破解,系统将敞开大门完全不设防.另一方面,密码这把钥匙本身就是非常敏感的数据:大多数 ...

  6. MVC5 网站开发之七 用户功能 1、角色的后台管理

    角色是网站中都有的一个功能,用来区分用户的类型.划分用户的权限,这次实现角色列表浏览.角色添加.角色修改和角色删除. 目录 奔跑吧,代码小哥! MVC5网站开发之一 总体概述 MVC5 网站开发之二 ...

  7. MVC5 网站开发之七 用户功能 2 用户添加和浏览

    目录 MVC5网站开发之一 总体概述 MVC5 网站开发之二 创建项目 MVC5 网站开发之三 数据存储层功能实现 MVC5 网站开发之四 业务逻辑层的架构和基本功能 MVC5 网站开发之五 展示层架 ...

  8. MVC5 网站开发之七 用户功能 3用户资料的修改和删除

    这次主要实现管理后台界面用户资料的修改和删除,修改用户资料和角色是经常用到的功能,但删除用户的情况比较少,为了功能的完整性还是坐上了.主要用到两个action "Modify"和& ...

  9. oAuth 使得第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权

    OAUTH协议为用户资源的授权提供了一个安全的.开放而又简易的标准.与以往的授权方式不同之处是OAUTH的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可 ...

随机推荐

  1. winform界面特效470多例

    一共470多例winform 界面特效的源码. 实例030 窗口颜色的渐变 实例说明 在程序设计时,可以通过设置窗体的BackColor属性来改变窗口的背景颜色.但是这个属性改变后整个窗体的客户区都会 ...

  2. php sleep函数延迟执行

    PHP sleep函数一般用于定时执行任务中,表示延迟多少秒在执行程序.这里主机吧主要给大家讲一下sleep函数的语法和应用实例. sleep函数语法: sleep(seconds); //secon ...

  3. vector用法

    转:http://www.cnblogs.com/wang7/archive/2012/04/27/2474138.html 在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结. ...

  4. 基于vue和svg的树形UI

      vue-svg-tree 基于vue和svg的动态树形UI 截图 应用 npm install vue-svg-tree 示例 <template> <div> <v ...

  5. JavaScript数组方法--slice、sort、splice

    数组常用方法应该只剩下最后这哥仨了,他们都是最早的ECMA-262标准的方法,结果写着写着,居然把他们写到最后了. slice:slice() 方法返回一个新的数组对象,这一对象是一个由 begin和 ...

  6. all-document

    1.memorymanagement-whitepaper J2SE5.0 JVM 垃圾回收器相关英文 链接: https://pan.baidu.com/s/1mzkMxuFE82sfeVOToMb ...

  7. Java能不能通过代码干预Java垃圾回收

    1.不能通过Java代码干预Java垃圾回收. 2.system.gc是请求运行垃圾回收器,不一定真的运行了垃圾回收器. 3.Java的system.gc不受代码控制. 4.影响Java虚拟机垃圾回收 ...

  8. 20164304姜奥——Exp1 PC平台逆向破解

    1.1 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串. 该程序同时包含另一个代码片段,ge ...

  9. swoole结合支持thinkphp 5.0版本

    安装swoole pecl install swoole 修改PHP配置文件php.ini加入 extension=swoole.so 有可能不需要人工去加,安装时自动加入进来了, 查看swoole扩 ...

  10. [Linux]CentOS与终端破墙

    来源:https://www.zybuluo.com/ncepuwanghui/note/954160 参考:https://blog.huihut.com/2017/08/25/LinuxInsta ...