更新管理员数据
1、 获取修改管理员的详情信息
点就修改按钮时,我们需要先获取要修改的分组表详情信息
接口分析
请求方式: GET /meiduo_admin/permission/admins/(?P<pk>\d+)/
请求参数: 通过请求头传递jwt token数据。
返回数据: JSON
{
"id": "用户id",
"username": "用户名",
"mobile": "手机号",
"email": "邮箱",
"groups": ['用户组id', ...],
"user_permissions": ['权限id', ...]
}
参数 | 类型 | 是否必须 | 说明 |
---|---|---|---|
username | str | 是 | 用户名 |
mobile | str | 是 | 手机号 |
str | 否 | 邮箱 | |
groups | list | 是 | 用户组id |
user_permissions | list | 是 | 权限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)
2、修改管理员
接口分析
请求方式: PUT /meiduo_admin/permission/admins/(?P<pk>\d+)/
请求参数: 通过请求头传递jwt token数据。
参数 | 类型 | 是否必须 | 说明 |
---|---|---|---|
username | str | 是 | 用户名 |
mobile | str | 是 | 手机号 |
password | int | 是 | 密码 |
str | 否 | 邮箱 | |
groups | list | 是 | 用户组id |
user_permissions | list | 是 | 权限id |
返回数据: JSON
{
"id": "用户id",
"username": "用户名",
"password": "密码",
"mobile": "手机号",
"email": "邮箱",
"groups": ['用户组id', ...],
"user_permissions": ['权限id', ...]
}
参数 | 类型 | 是否必须 | 说明 |
---|---|---|---|
username | str | 是 | 用户名 |
mobile | str | 是 | 手机号 |
password | int | 是 | 密码 |
str | 否 | 邮箱 | |
groups | list | 是 | 用户组id |
user_permissions | list | 是 | 权限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
# 重写父类的更新方法,让密码加密
def update(self, instance, validated_data):
user = super().update(instance, validated_data)
# 密码加密set_password
user.set_password(validated_data['password'])
user.save()
return user