django rest framework 学习笔记-实战商城3

 01用户模块模型定义_哔哩哔哩_bilibili  本博客借鉴至大佬的视频学习笔记

用户模块及商品数据表结构设计

from ckeditor.fields import RichTextField  # pip install django-ckeditor
from django.db import models# Create your models here.
# from wx.richtext import RichTextFieldfrom common.db import BaseModelclass GoodsGroup(BaseModel):"""商品分类"""name = models.CharField(verbose_name="分类名称", help_text="分类名称", max_length=15,blank=True,null=True)image = models.CharField(verbose_name="图片链接", help_text="图片链接", max_length=200, blank=True, null=True)status = models.BooleanField(verbose_name="是否启用", help_text="是否启用", default=False,blank=True,null=True)class Meta:db_table = 'goods_group'verbose_name = "商品分类表"verbose_name_plural = verbose_namedef __str__(self):return self.nameclass Goods(BaseModel):"""商品"""group = models.ForeignKey('GoodsGroup', verbose_name="分类", help_text="分类", max_length=15, on_delete=models.CASCADE)image = models.CharField(verbose_name="图片链接", help_text="图片链接", max_length=200, blank=True, null=True)title = models.CharField(verbose_name="标题", help_text="标题", max_length=20, blank=True,null=True)desc = models.CharField(verbose_name="商品描述", help_text="商品描述", max_length=200, blank=True,null=True)price = models.DecimalField(verbose_name="商品价格", help_text="商品价格", max_digits=10, decimal_places=2, blank=True,null=True)cover = models.ImageField(verbose_name="封面图链接", help_text="封面图链接", max_length=200, blank=True,null=True)stock = models.IntegerField(verbose_name="库存", help_text="库存", blank=True, null=True, default=1)sales = models.IntegerField(verbose_name="销量", help_text="销量", blank=True, null=True, default=0)is_on = models.BooleanField(verbose_name="是否上架", help_text="是否上架", blank=True, null=True, default=False)recommend = models.BooleanField(verbose_name="是否推荐", help_text="是否推荐", blank=True, null=True, default=False)class Meta:db_table = 'goods'verbose_name = '商品表'verbose_name_plural = verbose_namedef __str__(self):return self.titleclass Detail(BaseModel):"""商品详情"""goods = models.OneToOneField('Goods', verbose_name="商品", on_delete=models.CASCADE, max_length=200)producer = models.CharField(verbose_name='厂商', help_text='厂商', max_length=200, blank=True,null=True)norms = models.CharField(verbose_name='规格', help_text='规格', max_length=200, blank=True,null=True)details = RichTextField(verbose_name='商品详情', help_text='商品详情', max_length=200,blank=True,null=True)class Meta:db_table = 'details'verbose_name = '详情'verbose_name_plural = verbose_namedef __str__(self):return self.goodsclass GoodsBanner(BaseModel):"""商品轮播图"""title = models.CharField(verbose_name='轮播图名称', help_text='轮播图名称', max_length=20, blank=True)image = models.ImageField(verbose_name='轮播图链接', help_text='轮播图链接', max_length=200, blank=True)# url = models.CharField(verbose_name='跳转的地址',help_text='跳转的地址',max_length=200,blank=True)status = models.BooleanField(verbose_name='是否启用', help_text='是否启用', default=False,blank=True,null=True)seq = models.IntegerField(verbose_name='顺序', help_text='顺序', default=1, blank=True,null=True)class Meta:db_table = 'banner'verbose_name = '首页商品轮播'verbose_name_plural = verbose_namedef __str__(self):return self.titleclass Collect(models.Model):"""商品收藏"""user = models.ForeignKey('users.User', help_text='用户ID', verbose_name='用户ID', on_delete=models.CASCADE,blank=True,null=True)goods = models.ForeignKey('goods.Goods', help_text="商品ID", verbose_name="商品ID", on_delete=models.CASCADE,blank=True,null=True)class Meta:db_table = 'collect'verbose_name = "收藏商品"verbose_name_plural = verbose_namedef __str__(self):return self.goods

Django自带admin配置

from django.contrib import admin
from .models import GoodsGroup,Goods,Detail,GoodsBanner,Collect
# Register your models here.@admin.register(GoodsGroup)
class GoodsGroupAdmin(admin.ModelAdmin):list_display = ['name','status']@admin.register(Goods)
class GoodsAdmin(admin.ModelAdmin):list_display = ['title','group','price','stock','sales','is_on']@admin.register(Detail)
class DetailGroupAdmin(admin.ModelAdmin):list_display = ['goods', 'producer','norms']@admin.register(GoodsBanner)
class GoodsBannerAdmin(admin.ModelAdmin):list_display = ['title', 'status']@admin.register(Collect)
class CollectAdmin(admin.ModelAdmin):list_display = ['user', 'goods']

商品首页接口实现

class IndexView(APIView):"""首页数据展示"""def get(self,request):"""返回轮播图、商品分类"""group = GoodsGroup.objects.filter(status=True)groupSer =GoodsGroupSerializer(group,many=True)# 轮播图banner = GoodsBanner.objects.filter(status=True)bannerSer = GoodsBannerSerializer(banner,many=True)# 推荐的商品goods = Goods.objects.filter(recommend=True)goodsSer = GoodsSerializer(goods,many=True)# 返回数据result = {'banner': bannerSer.data,'goods':goodsSer.data,'group':groupSer.data}return Response({"message":'ok','data':result},status=status.HTTP_200_OK)# 商品首页
path('index/', IndexView.as_view()),

商品列表获取和分类排序接口

# view
class GoodsView(ReadOnlyModelViewSet):""""商品列表接口"""serializer_class = GoodsSerializer# 选择上架的商品queryset = Goods.objects.filter(is_on=True),# 实现商品分类和推荐类过滤filterset_fields = ('group','recommend')# 通过价格和销量排序ordering_fields =('sales','price','create_time')# url
# 商品列表接口
path('goods/', GoodsView.as_view({"get":'list'})),
# 单个商品获取
path('goods/<int:pk>/', GoodsView.as_view({"get":'retrieve'})),# setting
# 过滤器信息配置、排序器配置
'DEFAULT_FILTER_BACKENDS':['django_filters.rest_framework.DjangoFilterBackend','rest_framework.filters.OrderingFilter']# 注册
'django_filters',

商品的收藏与取消收藏接口

# view
class CollectView(mixins.RetrieveModelMixin,mixins.CreateModelMixin,mixins.ListModelMixin,mixins.DestroyModelMixin,GenericViewSet):"""商品收藏与取消create: 收藏delete: 取消list: 收藏列表"""queryset = Collect.objects.all()serializer_class = CollectSerializerpermission_classes =  [IsAuthenticated,CollectPermissions]filterset_fields = ("user",)def create(self, request, *args, **kwargs):# 获取请求参数user = request.userparams_user_id = request.data.get('user')# 检验请求参数中的id是否当前登录的用户IDif user.id != params_user_id:return Response({'error':'你没有用户权限访问该信息'},status=status.HTTP_400_BAD_REQUEST)return super().create(request, *args, **kwargs)def list(self, request, *args, **kwargs):"""商品收藏列表"""queryset = self.filter_queryset(self.get_queryset())queryset = queryset.filter(user=request.user)serializer = self.get_serializer(queryset, many=True)return Response(serializer.data)# perssion
from rest_framework import permissions
class CollectPermissions(permissions.BasePermission):"""Custom permission to only allow owners of an object to edit it."""def has_object_permission(self, request, view, obj):# 判断是否是管理员if request.user.is_superuser:return True# 判断当前的用户对象和登录的用户对象是否是同一个,防止越权return obj == request.user# url
# 收藏商品
path('collect/', CollectView.as_view({"post":'create','get':'list'})),
# 取消收藏
path('collect/del/<int:pk>/', CollectView.as_view({"delete":'destroy'})),

商品购物车的接口实现: 购物车添加数量、修改商品购物车状态、加购商品

# serializer
from rest_framework import serializers
from apps.cart.models import Cart
from apps.goods.serializers import GoodsSerializerclass CartSerializer(serializers.ModelSerializer):"""用户的模型序列化器-写入"""class Meta:model = Cartfields = '__all__'class ReadInfoSerializer(serializers.ModelSerializer):"""用户的模型序列化器-读取"""goods =GoodsSerializer()class Meta:model = Cartfields = '__all__'# view
from rest_framework import status
from rest_framework.response import Response
from rest_framework.viewsets import GenericViewSet,mixins
from .models import Cart
from .serializers import CartSerializer, ReadInfoSerializer# Create your views here.class  CartViecw(GenericViewSet,mixins.CreateModelMixin,mixins.UpdateModelMixin,mixins.DestroyModelMixin,mixins.ListModelMixin):queryset = Cart.objects.all()serializer_class = CartSerializerdef get_serializer_class(self):# 实现读写操作使用不同的序列化器if self.action == 'list':return ReadInfoSerializerelse:return self.serializer_classdef create(self, request, *args, **kwargs):user = request.usergoods  =request.data.get('goods')if Cart.objects.filter(user=user,goods=goods):# 该商品存在cart_goods = Cart.objects.get(user=user,goods=goods)cart_goods.number +=1cart_goods.save()# 商品序列化serializer = self.get_serializer(cart_goods)return Response(serializer.data,status=status.HTTP_201_CREATED)else:# 没有该商品则进行添加该商品request.data['user'] = user.idreturn super().create(request,*args,**kwargs)def list(self, request, *args, **kwargs):query =self.get_queryset().filter(user=request.user)serializer = self.get_serializer(query, many=True)return Response(serializer.data)def update_goods_status(self,request, *args, **kwargs):obj =self.get_object()obj.is_checked = not obj.is_checkedobj.save()return Response({"message":'修改成功'},status=status.HTTP_200_OK)def update_goods_number(self,request, *args, **kwargs):number = request.data.get('number')obj = self.get_object()if not isinstance(number,int): return Response({'error':'参数number只可为INT类型'})if number > obj.goods.stock:return Response({"message": "数量不可超过该商品的库存数量"}, status=status.HTTP_422_UNPROCESSABLE_ENTITY)elif number <= 0:obj.delete()return Response({"message":"修改成功,已删除"},status=status.HTTP_200_OK)else:obj.number = numberobj.save()return Response({"message": "修改成功"}, status=status.HTTP_200_OK)# url
from apps.cart.views import CartViecw
urlpatterns = [# 商品首页path('cart/', CartViecw.as_view({"post":'create','get':'list'})),# 修改商品购物车的状态path('cart/<int:pk>/checked/', CartViecw.as_view({"put":'update_goods_status'})),# 修改商品数量path('cart/<int:pk>/number/', CartViecw.as_view({"put": 'update_goods_number'})),]

以上是django restframework商城的后端实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/703934.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MATLAB环境下基于PSO-DBN-ELM方法的图像分类

在纯数据驱动的图像识别方法中&#xff0c;深度信念网络DBN识别模型具备较好的识别性能。对于DBN模型而言&#xff0c;可利用的数据越多&#xff0c;挖掘的信息也越多&#xff0c;建立的模型就越准确。然而DBN本身仍存在一定的不足之处&#xff0c;一方面由于DBN内部包含多层限…

servlet---->request.getHeader(“X-Requested-With“);有什么作用?

X-Requested-With 是一个自定义的HTTP请求头&#xff0c;主要用于在服务器端识别请求是由Ajax技术发起的还是由其他技术发起的。这个请求头是由浏览器或客户端应用程序添加的&#xff0c;因此其值可能取决于发送请求的客户端或者开发者的选择。 如果请求不是通过JavaScript的 …

微信小程序支付(前后端都包含)

Java中换取微信支付唯一订单号(用于换取支付窗口) /*** 微信小程序支付*/PostMapping(value "/xcxPay")ResponseBodypublic Map<String,Object> miniAppPay(RequestBody byte[] req) {HashMap<String, Object> objectObjectMap new HashMap<>();…

【软件测试】--功能测试1

一、测试介绍 什么是软件&#xff1f; 控制计算机硬件工作的工具。 什么是软件测试&#xff1f; 使用技术手段验证软件是否满足需求 软件测试的目的&#xff1f; 减少软件缺陷&#xff0c;保证软件质量。 测试主流技能 1、功能测试 2、自动化测试 3、接口测试 4、性能测试 ​…

MySQL-事务,properties文件解析,连接池

1.事务机制管理 1.1 Transaction事务机制管理 默认情况下是执行一条sql语句就保存一次&#xff0c;那么比如我们需要三条数据同时成功或同时失败就需要开启事务机制了。开启事务机制后执行过程中发生问题就会回滚到操作之前&#xff0c;相当于没有执行操作。 1.2 事务的特征 事…

【初始RabbitMQ】延迟队列的实现

延迟队列概念 延迟队列中的元素是希望在指定时间到了之后或之前取出和处理消息&#xff0c;并且队列内部是有序的。简单来说&#xff0c;延时队列就是用来存放需要在指定时间被处理的元素的队列 延迟队列使用场景 延迟队列经常使用的场景有以下几点&#xff1a; 订单在十分…

Anaconda下安装torch-geometric

主要流程参考&#xff1a;https://blog.csdn.net/weixin_45671036/article/details/130617637 https://blog.csdn.net/weixin_43756314/article/details/130225038?ops_request_misc&request_id&biz_id102&utm_term%E5%80%9F%E5%8A%A9anaconda%20%E5%AE%89%E8%A3%…

配置vscode,使其可以运行C++11特性的代码(如vector)

配置vscode&#xff0c;使其可以运行C11特性的代码 封面引用自配置教程的B站视频&#xff0c;非常详细的视频&#xff0c;感谢视频作者的贡献。 文章目录 配置vscode&#xff0c;使其可以运行C11特性的代码Step 1: 基础配置Step 2: 调整Code Runner的配置Step 3: 更改tasks.jso…

【Spring连载】使用Spring Data的Repositories----定义Repository接口

【Spring连载】使用Spring Data的Repositories----定义Repository接口 一、微调Repository定义二、使用多个Spring Data模块的Repositories 要定义repository接口&#xff0c;首先需要定义特定于域&#xff08;domain&#xff09;类的repository接口。接口必须继承Repository&a…

8.openEuler操作系统网络管理和防火墙(二)

openEuler OECA认证辅导,标红的文字为学习重点和考点。 如果需要做实验,建议安装麒麟信安、银河麒麟、统信等具有图形化的操作系统,其安装与openeuler基本一致。 3.通过IP命令配置网络 配置IP地址: 使用ip命令为接口配置地址,命令格式如下,其中 interface-name 为网卡名…

一文7个步骤教你搭建测试web测试项目实战环境

​今天小编&#xff0c;给大家总结下web 测试实战的相关内容&#xff0c;一起来学习下吧&#xff01; web项目实战可按顺序依次为&#xff1a;【搭建测试环境】、【需求评审】、【编写测试计划】、【分析测试点.编写测试用例】、【用例评审】、【执行用例提bug】、【测试报告】…

广东珠宝行业为什么要开展珠宝神秘顾客调查呢?

在竞争激烈的珠宝市场中&#xff0c;品牌形象、服务质量以及顾客满意度是决定一个企业成功与否的关键因素。为了更好地了解顾客需求&#xff0c;优化服务流程&#xff0c;提升顾客满意度&#xff0c;珠宝行业开展神秘顾客调查显得尤为重要。以下从几个方面详细阐述珠宝行业为何…

undo日志详解

一、undo日志介绍 上一节详细的说了redo日志&#xff0c;redo日志的功能就是把增删改操作都记录着&#xff0c;如果断电导致内存中的脏页丢失&#xff0c;可以根据磁盘中的redo日志文件进行恢复。redo日志被设计出来是为了保证数据库的持久性&#xff0c;undo日志设计出来是为…

AI 绘画:人工智能绘画之美

人工智能&#xff08;AI&#xff09;是当今科技领域的热门话题&#xff0c;它不仅可以帮助我们解决各种复杂的问题&#xff0c;还可以创造出令人惊叹的艺术作品。AI 绘画是一种利用 AI 技术生成图像的方法&#xff0c;它可以模仿不同的风格、主题和技巧&#xff0c;甚至可以创造…

Qt Linux下调用OpenGL的glu.h报错:error: GL/glu.h: No such file or directory

Qt Linux下调用OpenGL的glu.h报错&#xff1a;error: GL/glu.h: No such file or directory 引言一、问题描述二、解决方案三、解决过程记录3.1 定位问题3.2 尝试使用yum命令安装3.3 从网上下载到本地进行安装 引言 在Windows上正常运行的OpenGL程序&#xff0c;到Linux下突然…

cuda学习笔记(2)

一 专业名词 1 分支断定 2 一致性和同一性 3 常见名词汇总 4 加速比 二 GPU架构构述 GPU就是将cpu的数据存储单元去掉&#xff0c;也就是保留执行单元&#xff0c;GPU就是多个执行单元 1 GPU设计思路&#xff0c;指令流共享&#xff0c;同时执行&#xff0c;数据切分成小块 …

四种主流的prompt框架

省流版&#xff1a; 文章介绍了在使用GPT时的四种prompt框架&#xff0c;有利于使用者打磨提问风格&#xff0c;与GPT进行更好的交互以提高生产力&#xff0c;能帮助大家有效提高工作效率~ 创作不易&#xff0c;如果对你有帮助的话&#xff0c;还请三连支持~ 想要使用Prompt…

MySQL的21个SQL经验

1. 写完SQL先explain查看执行计划(SQL性能优化) 日常开发写SQL的时候,尽量养成这个好习惯呀:写完SQL后,用explain分析一下,尤其注意走不走索引。 explain select userid,name,age from user where userid =10086 or age =18;2、操作delete或者update语句,加个limit(S…

jQuery简介与解析 - 掌控网页互动的魔法工具

jQuery简介与解析 - 掌控网页互动的魔法工具 摘要&#xff1a;本文将带您了解jQuery这一强大且流行的JavaScript库&#xff0c;探讨其特点、优势以及如何在网页开发中发挥巨大作用。我们将从jQuery的基本概念入手&#xff0c;逐步深入解析其核心功能&#xff0c;助您轻松掌握这…

phpspreadsheet导出数据和图片到excel

仅作记录&#xff0c;废话不多说 前提是已经安装了phpspreadsheet &#xff08; composer require phpoffice/phpspreadsheet &#xff09; 一、 数据拼装&#xff0c;调用excel类 <?php /*** 电子台账* Date: 2023/4/20* Time: 17:28*/namespace app\store\controlle…