保存管理员数据
在保存数据之前我们需要获取权限表数据和分组表数据展示,权限表数据的获取接口已经完成,我们只需要获取分组表数据
接口分析
请求方式: GET /meiduo_admin/permission/groups/simple/
# 权限分组表路由
url(r'^permission/groups/simple/$', admin.AdminView.as_view({'get': 'simple'})),
请求参数: 通过请求头传递jwt token数据。
返回数据: JSON
[
{
"id": 1,
"name": "广告组"
},
{
"id": 2,
"name": "商品SKU组"
},
......
]
返回值类型是否必须说明Idint是分组idname数组是分组名称
后端实现
# AdminView继承的是ModelViewSet 所以获取分组逻辑还是使用同一个类视图
from rest_framework.viewsets import ModelViewSet
from meiduo_admin.serializers.admin import AdminSerializer
from users.models import User
from meiduo_admin.utils import UserPageNum
from django.contrib.auth.models import Group
from rest_framework.response import Response
from meiduo_admin.serializers.group import GroupSerialzier
class AdminView(ModelViewSet):
serializer_class = AdminSerializer
# 获取管理员用户
queryset = User.objects.filter(is_staff=True)
pagination_class = UserPageNum
# 获取分组数据
def simple(self, reqeust):
pers = Group.objects.all()
ser = GroupSerialzier(pers, many=True)
return Response(ser.data)
运行效果:
接口分析
请求方式:POST /meiduo_admin/permission/admins/
请求参数: 通过请求头传递jwt token数据。
参数类型是否必须说明usernamestr是用户名mobilestr是手机号passwordint是密码emailstr否邮箱groupslist是用户组iduser_permissionslist是权限id返回数据: JSON
{
"id": "用户id",
"username": "用户名",
"password": "密码",
"mobile": "手机号",
"email": "邮箱",
"groups": ['用户组id', ...],
"user_permissions": ['权限id', ...]
}
参数类型是否必须说明usernamestr是用户名mobilestr是手机号emailstr否邮箱groupslist是用户组iduser_permissionslist是权限id
后端实现
# AdminView继承的是ModelViewSet 所以保存分组逻辑还是使用同一个类视图
from rest_framework.viewsets import ModelViewSet
from meiduo_admin.serializers.admin import AdminSerializer
from users.models import User
from meiduo_admin.utils import UserPageNum
from django.contrib.auth.models import Group
from rest_framework.response import Response
from meiduo_admin.serializers.group import GroupSerialzier
class AdminView(ModelViewSet):
serializer_class = AdminSerializer
# 获取管理员用户
queryset = User.objects.filter(is_staff=True)
pagination_class = UserPageNum
# 获取分组数据
def simple(self, reqeust):
pers = Group.objects.all()
ser = GroupSerialzier(pers, many=True)
return Response(ser.data)
序列化器 【直接保存密码是没有加密的,所以还要重写父类的方法】
from rest_framework import serializers
from users.models import User
class AdminSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = "__all__"
extra_kwargs = {
'password': {
'write_only': True
}
}
# 重写父类方法,增加管理员权限属性
def create(self, validated_data):
# 添加管理员字段
validated_data['is_staff'] = True
# 调用父类方法创建管理员用户
admin = super().create(validated_data)
# 用户密码加密
password = validated_data['password']
admin.set_password(password)
admin.save()
return admin