摘要:实战小练习需求获取指定组下的列表往用户组添加用户从组中删除用户需求分析获取指定组下的列表网用户组添加用户从组中删除用户走界面不行项目结构主路由配置文件开源运维平台子路由配置文件序列
实战小练习 需求
users
userGroups
groups
groupUsers
---- get : 获取指定组下的user列表
-----put:往用户组添加用户
-----delete:从组中删除用户
permissions
userPermissions
groupPermissions
需求分析groupUsers
---- get : 获取指定组下的user列表 -----create:网用户组添加用户 -----delete:从组中删除用户
GET: /api/groupUser/1
POST: r = request.post("http://192.168.33.10:8080/groupUsers/",data=json) 【data={"uid":1,"gid":1}】
DELETE: r = request.delete("http://192.168.33.10:8080/groupUsers/",data=json) 【data={"uid":1,"gid":1}】 #走界面不行
[vagrant@localhost day5]$ tree devops/ devops/ ├── apps │ ├── groupUsers │ │ ├── __init__.py │ │ ├── __pycache__ │ │ ├── router.py │ │ ├── serializers.py │ │ └── views.py │ └── idc │ ├── admin.py │ ├── apps.py │ ├── __init__.py │ ├── migrations │ │ ├── 0001_initial.py │ │ ├── __init__.py │ │ └── __pycache__ │ ├── models.py │ ├── __pycache__ │ ├── router.py │ ├── serializers.py │ ├── tests.py │ ├── urls.py │ └── views.py ├── devops │ ├── __init__.py │ ├── __pycache__ │ ├── settings.py │ ├── urls.py │ └── wsgi.py └── manage.py
devops/urls.py #主路由配置文件
from django.conf.urls import url,include from rest_framework.routers import DefaultRouter from rest_framework.documentation import include_docs_urls from groupUsers.router import group_users_router from idc.router import idc_router router = DefaultRouter() router.registry.extend(group_users_router.registry) router.registry.extend(idc_router.registry) urlpatterns = [ url(r"^",include(router.urls)), url(r"^docs/", include_docs_urls("开源运维平台")) ]
devops/groupUsers/router.py #子路由配置文件
from rest_framework.routers import DefaultRouter from .views import GroupUsersViewset group_users_router = DefaultRouter() group_users_router.register(r"group-users",GroupUsersViewset,base_name="group-users")
devops/groupUsers/serializers.py #序列化文件
from rest_framework import serializers from django.contrib.auth.models import Group class GroupSerializer(serializers.Serializer): id = serializers.IntegerField(read_only=True) name = serializers.CharField(required=False) class UserSerializer(serializers.Serializer): id = serializers.IntegerField(read_only=True) username = serializers.CharField(required=False)
devops/groupUsers/views.py #视图文件
from rest_framework import viewsets,mixins,response,status from django.contrib.auth.models import Group,User from django.http import QueryDict from .serializers import GroupSerializer,UserSerializer class GroupUsersViewset(viewsets.GenericViewSet): serializer_class = UserSerializer def get_group_object(self): # Perform the lookup filtering. lookup_url_kwarg = self.lookup_url_kwarg or self.lookup_field #lookup_field=pk,kwargs[lookup_url_kwarg]=传入的pk值 filter_kwargs = {self.lookup_field: self.kwargs[lookup_url_kwarg]} return Group.objects.get(**filter_kwargs) def get_queryset(self): groupObj = self.get_group_object() return groupObj.user_set.all() def retrieve(self, request, *args, **kwargs): queryset = self.get_queryset() serializer = self.get_serializer(queryset,many=True) return response.Response(serializer.data) def create(self, request, *args, **kwargs): """ int异常补货 :param request: :param args: :param kwargs: :return: """ groupObj = Group.objects.get(pk=request.data["gid"]) userObj = User.objects.get(pk=request.data["uid"]) groupObj.user_set.add(userObj) return response.Response(status=status.HTTP_204_NO_CONTENT) def destroy(self,request,*args,**kwargs): groupObj = self.get_group_object() #获取 userObj = User.objects.get(pk=request.data["uid"]) groupObj.user_set.reverse(userObj) return response.Response(status=status)
其余实例详细请看:
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/42739.html
摘要:为什么要进行前后端分离多端适配开发模式的流行前后端职责不清前后端开发效率问题,前后端相互等待前段一直配合后端,能力受到限制后端开发语言和模板高度耦合,导致开发语言依赖严重前后端分离的缺点前后端学习门槛增加数据依赖,导致文档的重要性增加前段工 DRF 为什么要进行前后端分离 PC,APP,PAD多端适配 SPA开发模式的流行 前后端职责不清 前后端开发效率问题,前后端相互等待 前段一直...
摘要:基础之二简介官方文档安装与配置安装配置重新创建数据库并配置新建一个的将座位,并做配置加入环境变量定义好主备路由主路由项目路由创建名称地址联系电话邮箱创建数据库同步生成数据北京机房北京市酒仙桥北京机房上海机房上海上 DRF基础之二 简介 官方文档 Requirements REST framework requires the following: Python (2.7, 3.4, ...
摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...
摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...
摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...
阅读 2196·2021-11-25 09:43
阅读 1164·2021-11-23 09:51
阅读 3499·2021-11-23 09:51
阅读 3627·2021-11-22 09:34
阅读 1543·2021-10-09 09:43
阅读 2119·2019-08-30 15:53
阅读 3160·2019-08-30 14:07
阅读 568·2019-08-28 18:14