基本配置

# 设置数据库为使用的mysql
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'library',
        'USER': 'root',
        'PASSWORD': 'password',
        'HOST': '10.18.99.166',
        'PORT': '3306',
    }
}

# 设置语言为 中文
LANGUAGE_CODE = 'zh-hans'

# 设置时区为 中国
TIME_ZONE = 'Asia/Shanghai'

# 自定义模块 与 静态文件 位置
TEMPLATES = [
    {
    ...
'DIRS': [os.path.join(BASE_DIR,  'templates')],
    ...
	},
]

# 静态文件目录,为包含一个元素的元组; 此句放于 STATIC_URL='/static' 语句后
STATICFILES_DIRS = (os.path.join(BASE_DIR,'static'),)    

一、 Form 表单

1、在获取信息较多时,使用Django自带的form类比较简单,其又分为以下两类
form 与 modelForm:
前者获取信息,不需要存入数据库;
后者获取信息,一般需要存入数据库;

from django import forms
class LoginForm(forms.Form):
  username = forms.CharField()
  password = forms.CharField(label="密码",widget=forms.PasswordInput)

在注册与更新时,CreateView更简单,直接使用即可,但是若是需要注册的信息需要各种校验还是自定义一个RegisterForm比较方便。

2、在select需要联动时,可以考虑自定义form

3、在数据量所需更少时,可以直接通过ajax传递数据

二、自带管理系统使用

创建管理员账号 Superuser
虚拟环境中输入 python manage.py createsuperuser

# 新建用户,在用户注册时常使用,此处的User可以为继承了AbstractUser的自定义User
u = User.objects.create_user(username=username, password=password, email=email)
# 获取登录后的用户信息,以用户名字为例
user_name = request.user.username 

注册、登录、密码修改的实现方式

1、注册
在注册时,因为有特殊需要,所以手写了一个RegisterFrom(forms.Form),此处加入一些多选框。在获取到前端传过来的数据后,通过楼上的新建用户实现用户的注册。
2、登录
也是自定义一个简单Form(forms.Form),通过获取前端传过来的数据,使用 user = authenticate(username=cd['username'],password=cd['password']),验证用户输入是否正确实现登录。
3、密码修改
使用了自带的PasswordChangeView(),自定义了前端模板实现。

以上,都有使用django自带的功能实现需求。

权限管理

from django.contrib.auth.models import Permission

# 在Views.py中检查用户权限
myuser.hasperm('appname.haha') # 传递参数时要加入model所属app
# 或是在HTML模板里
{% if perms.appname%}   # 
  <p>You have permission to do something in the appname.</p>
  {% if perms.appname.can_vote %}
    <p>You can vote!</p>
  {% endif %}
{% else %}
  <p>You dont have permission to do anything in the appname.</p>
{% endif %}

# 增删权限
myuser.user_permissions.add(per1,per2)
myuser.user_permissions.remove(per1,per2)
myuser.user_permissions.clear() # 清空权限

user.get_all_permissions() # 列出用户所有权限,返回值为permission_name的list
user.get_group_permissions() # 列出用户 所属group的权限

三、界面信息展示

1、后端传回queryset,前端用 模板语言遍历到表格中。若是想用datatable处理之,则在datatable初始化时对各列重命名,例

<tbody>

{% for a in queryset %}
<tr>
  <td hidden>{{a.id}}</td>
  <td>{{ a.name }}</td>
</tr>
{% endfor %}

</tbody>


<script>
  var table = $('#table_id').DataTable({
    columns:[
      {data:'id'},
      {data:'name'},
    ]
  })
  table.select.style('os') # 想多选行时使用
</script>

2、前端在datatable中直接通过自带的ajax功能,获取数据。

1、登录认证 参考
https://www.cnblogs.com/lvye001/p/10141365.html
https://www.cnblogs.com/zhanghongfeng/p/8331493.html