目錄html
生鮮超市(七) 生鮮超市(八) 生鮮超市(九) python
生鮮超市(十) 生鮮超市(十一) 生鮮超市(十二) 生鮮超市(十三) git
代碼下載github
githubshell
教程數據庫
學習自慕課網-前端vue結合後端DjangoFramework的在線生鮮超市 後端
(1) urlapi
#drf文檔,title自定義
path('docs',include_docs_urls(title='仙劍奇俠傳')),
訪問:http://127.0.0.1:8000/docs 就能夠自動生成
(2)drf文檔的優勢:
(3)代碼中註釋的格式:
ViewSet的格式,更多請看官方文檔
class GoodsListViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin,viewsets.GenericViewSet): ''' list: 商品列表,分頁,搜索,過濾,排序 retrieve: 獲取商品詳情 '''
(4)Description
添加字段的描述有三種方式:
用戶我的信息修改,由於手機號是驗證過的,不能隨便改
在會員中心頁面,想要獲取我的信息,只需在UserViewset中多繼承一個類:mixins.RetrieveModelMixin
(1)用戶詳情的序列化
users/serializers.py
class UserDetailSerializer(serializers.ModelSerializer): """ 用戶詳情 """ class Meta: model = User fields = ("name", "gender", "birthday", "email","mobile")
(2)users/views.py
class UserViewset(CreateModelMixin,mixins.RetrieveModelMixin,viewsets.GenericViewSet): ''' 用戶 ''' serializer_class = UserRegSerializer queryset = User.objects.all() authentication_classes = (JSONWebTokenAuthentication, authentication.SessionAuthentication) def create(self, request, *args, **kwargs): serializer = self.get_serializer(data=request.data) serializer.is_valid(raise_exception=True) user = self.perform_create(serializer) re_dict = serializer.data payload = jwt_payload_handler(user) re_dict["token"] = jwt_encode_handler(payload) re_dict["name"] = user.name if user.name else user.username headers = self.get_success_headers(serializer.data) return Response(re_dict, status=status.HTTP_201_CREATED, headers=headers) #這裏須要動態權限配置 #1.用戶註冊的時候不該該有權限限制 #2.當想獲取用戶詳情信息的時候,必須登陸才行 def get_permissions(self): if self.action == "retrieve": return [permissions.IsAuthenticated()] elif self.action == "create": return [] return [] #這裏須要動態選擇用哪一個序列化方式 #1.UserRegSerializer(用戶註冊),只返回username和mobile,會員中心頁面須要顯示更多字段,因此要建立一個UserDetailSerializer #2.問題又來了,若是註冊的使用userdetailSerializer,又會致使驗證失敗,因此須要動態的使用serializer def get_serializer_class(self): if self.action == "retrieve": return UserDetailSerializer elif self.action == "create": return UserRegSerializer return UserDetailSerializer #雖然繼承了Retrieve能夠獲取用戶詳情,可是並不知道用戶的id,全部要重寫get_object方法 #重寫get_object方法,就知道是哪一個用戶了 def get_object(self): return self.request.user def perform_create(self, serializer): return serializer.save()
主要添加的內容:
如今就能夠從數據庫獲取用戶的信息了
用戶我的信息修改
只須要多添加一個繼承mixins.UpdateModelMixin就能夠了
class UserViewset(CreateModelMixin,mixins.RetrieveModelMixin,mixins.UpdateModelMixin,viewsets.GenericViewSet):
(1)用戶收藏商品詳情
user_operation/serializer.py中添加
class UserFavDetailSerializer(serializers.ModelSerializer): ''' 用戶收藏詳情 ''' #經過商品id獲取收藏的商品,須要嵌套商品的序列化 goods = GoodsSerializer() class Meta: model = UserFav fields = ("goods", "id")
(2)user_operation/views.py
動態設置serializer
#動態選擇serializer def get_serializer_class(self): if self.action == "list": return UserFavDetailSerializer elif self.action == "create": return UserFavSerializer return UserFavSerializer
# user_operaton/views.py from rest_framework import viewsets from rest_framework import mixins from .models import UserFav from .serializers import UserFavSerializer,UserFavDetailSerializer from rest_framework.permissions import IsAuthenticated from utils.permissions import IsOwnerOrReadOnly from rest_framework_jwt.authentication import JSONWebTokenAuthentication from rest_framework.authentication import SessionAuthentication class UserFavViewset(viewsets.GenericViewSet, mixins.ListModelMixin, mixins.CreateModelMixin, mixins.DestroyModelMixin): ''' 用戶收藏 ''' #permission是用來作權限判斷的 # IsAuthenticated:必須登陸用戶;IsOwnerOrReadOnly:必須是當前登陸的用戶 permission_classes = (IsAuthenticated,IsOwnerOrReadOnly) #auth使用來作用戶認證的 authentication_classes = (JSONWebTokenAuthentication,SessionAuthentication) #搜索的字段 lookup_field = 'goods_id' #動態選擇serializer def get_serializer_class(self): if self.action == "list": return UserFavDetailSerializer elif self.action == "create": return UserFavSerializer return UserFavSerializer def get_queryset(self): #只能查看當前登陸用戶的收藏,不會獲取全部用戶的收藏 return UserFav.objects.filter(user=self.request.user)
在會員中心能夠看到已收藏的商品以及詳細信息,點刪除,能夠刪除對應的商品
(1)user_operation/serializers.py
class LeavingMessageSerializer(serializers.ModelSerializer): ''' 用戶留言 ''' # 獲取當前登陸的用戶 user = serializers.HiddenField( default=serializers.CurrentUserDefault() ) #read_only:只返回,post時候能夠不用提交,format:格式化輸出 add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta: model = UserLeavingMessage fields = ("user", "message_type", "subject", "message", "file", "id" ,"add_time")
(2)user_operation/views.py
class LeavingMessageViewset(mixins.ListModelMixin, mixins.DestroyModelMixin, mixins.CreateModelMixin, viewsets.GenericViewSet): """ list: 獲取用戶留言 create: 添加留言 delete: 刪除留言功能 """ permission_classes = (IsAuthenticated, IsOwnerOrReadOnly) authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication) serializer_class = LeavingMessageSerializer # 只能看到本身的留言 def get_queryset(self): return UserLeavingMessage.objects.filter(user=self.request.user)
(3)配置url
# 配置用戶留言的url router.register(r'messages', LeavingMessageViewset, base_name="messages")
能夠獲取、刪除留言等功能
(1)user_operation/serializers.py
class AddressSerializer(serializers.ModelSerializer): user = serializers.HiddenField( default=serializers.CurrentUserDefault() ) add_time = serializers.DateTimeField(read_only=True, format='%Y-%m-%d %H:%M') class Meta: model = UserAddress fields = ("id", "user", "province", "city", "district", "address", "signer_name", "add_time", "signer_mobile")
(2)user_operation/views.py
若是要實現增刪改查功能,只要繼承ModelViewSet就能夠了
class AddressViewset(viewsets.ModelViewSet): """ 收貨地址管理 list: 獲取收貨地址 create: 添加收貨地址 update: 更新收貨地址 delete: 刪除收貨地址 """ permission_classes = (IsAuthenticated, IsOwnerOrReadOnly) authentication_classes = (JSONWebTokenAuthentication, SessionAuthentication) serializer_class = AddressSerializer def get_queryset(self): return UserAddress.objects.filter(user=self.request.user)
(3)配置url
# 配置收貨地址 router.register(r'address',AddressViewset , base_name="address")