class AccountUserCreate(generics.CreateAPIView):
queryset = AccountUser.objects.all()
serializer_class = AccountUserSerializer
def perform_create(self, serializer):
auuser = User.objects.get(username=self.request.user)
serializer.save(user_id = auuser.id)
class AccountUserRetrieveUpdate(generics.RetrieveUpdateAPIView):
queryset = AccountUser.objects.all()
serializer_class = AccountUserSerializer
lookup_field = 'user_id'
def get_object(self):
queryset = self.filter_queryset(self.get_queryset())
auuser = User.objects.get(username=self.request.user)
filter_kwargs = {self.lookup_field:auuser.id}
obj = get_object_or_404(queryset,**filter_kwargs)
self.check_object_permissions(self.request, obj)
return obj
class UserCreate(generics.CreateAPIView):
serializer_class = UserSerializer
def create(self, request, *args, **kwargs):
user = User.objects.create(username=self.request.data['openid'])
token = Token.objects.create(user=user)
return Response(token.key, status=status.HTTP_201_CREATED)
为了解决token没有过期时间这个问题,我准备采用随机删除的方式删除一部的份token,由于没有登陆成功,客户端就会带上openid来登陆,此时只需检查更新·token
class UserCreate(generics.CreateAPIView):
serializer_class = UserSerializer
def create(self, request, *args, **kwargs):
if User.objects.get_or_create(username=self.request.data['openid']):
user = User.objects.get(username=self.request.data['openid'])
else:
user = User.objects.create(username=self.request.data['openid'])
#user = User.objects.get_or_create(username=self.request.data['openid'])
#user = User.objects.create(username=self.request.data['openid'])
if Token.objects.get(user=user):
return Response({'未更新token':'你的token没有过期'}, status=status.HTTP_201_CREATED)
else:
token = Token.objects.create(user=user)
return Response(token.key, status=status.HTTP_201_CREATED)
點(diǎn)擊查看更多內(nèi)容
1人點(diǎn)贊
評(píng)論
評(píng)論
共同學(xué)習(xí),寫下你的評(píng)論
評(píng)論加載中...
作者其他優(yōu)質(zhì)文章
正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦