资讯专栏INFORMATION COLUMN

Django基础之(十二) DRF综合小练习

lemon / 1040人阅读

摘要:实战小练习需求获取指定组下的列表往用户组添加用户从组中删除用户需求分析获取指定组下的列表网用户组添加用户从组中删除用户走界面不行项目结构主路由配置文件开源运维平台子路由配置文件序列

实战小练习 需求

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

相关文章

  • Django 基础(九)drf介绍.md

    摘要:为什么要进行前后端分离多端适配开发模式的流行前后端职责不清前后端开发效率问题,前后端相互等待前段一直配合后端,能力受到限制后端开发语言和模板高度耦合,导致开发语言依赖严重前后端分离的缺点前后端学习门槛增加数据依赖,导致文档的重要性增加前段工 DRF 为什么要进行前后端分离 PC,APP,PAD多端适配 SPA开发模式的流行 前后端职责不清 前后端开发效率问题,前后端相互等待 前段一直...

    琛h。 评论0 收藏0
  • Django基础(十)DRF

    摘要:基础之二简介官方文档安装与配置安装配置重新创建数据库并配置新建一个的将座位,并做配置加入环境变量定义好主备路由主路由项目路由创建名称地址联系电话邮箱创建数据库同步生成数据北京机房北京市酒仙桥北京机房上海机房上海上 DRF基础之二 简介 官方文档 Requirements REST framework requires the following: Python (2.7, 3.4, ...

    eccozhou 评论0 收藏0
  • DRF跨域后端解决django-cors-headers

    摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...

    lingdududu 评论0 收藏0
  • DRF跨域后端解决django-cors-headers

    摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...

    leeon 评论0 收藏0
  • DRF跨域后端解决django-cors-headers

    摘要:后端实现跨域第三方扩展在介绍之前,我先介绍两个概念同源策略跨域同源策略同源策略是一种约定,是浏览器的一种安全机制。这里同源需要协议域名端口三者都相同,否则不能进行访问。跨域不同源之间的网站通信就是跨域。 在使用django-rest-framework开发项目的时候我们总是避免不了跨域的问题,因为现在大多数的项目都是前后端分离,前后端项目部署在不同的web服务器上,因为我们是后端程序员...

    yanwei 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<