django-restful:serializers学习记录 和短信登录认证(三)

中间还有重要的一步 没有写 就是 什么时候调用了 发送短信 这个方法
这几篇写的有些乱
首先写 serializer 对 手机号进行验证 验证成功了 才调用 我们sms 功能 来发送短信

class SmsSerializer(serializers.Serializer):
    mobile = serializers.CharField(max_length=11)

    def validate_mobile(self, mobile):
        """
        验证手机号码
        :param data:
        :return:
        """
        #配置到settings中 更好  电话号码正则表达式
        REGEX_MOBILE = '^1[358]\d{9}$|^147\d{8}$|^176\d{8}$'

        # 手机是否已经注册
        if User.objects.filter(mobile=mobile).count():
            raise serializers.ValidationError('用户已经存在')

        # 验证手机号码是否合法
        if not re.match(REGEX_MOBILE, mobile):
            raise serializers.ValidationError('手机号码非法')

        # 验证码发送频率 timedelata 是一分钟前
        one_mintes_ago = datetime.now() - timedelta(hours=0, minutes=1, seconds=0)
        if VerifyCode.objects.filter(add_time__gt=one_mintes_ago, mobile=mobile).count():
            raise serializers.ValidationError('距离上一次发送未超过60s')

        return mobile

所以要排除 手机号码已存在,手机号码 非法 ,或者 验证码 发送申请过快这些情况
如果这些情况 都没有 就返回mobile 进行短信发送
views

class SmscodeViewset(CreateModelMixin, viewsets.GenericViewSet):
    """
    发送短信验证码
    """
    serializer_class = SmsSerializer

    def gennerate_code(self):
        """
        生成四位数字的验证码
        :return:
        """
        seeds = "1234567890"
        random_str = []
        for i in range(4):
            random_str.append(choices(seeds))
        return "".join(random_str)

    def create(self, request, *args, **kwargs):
        serializer = self.get_serializer(data=request.data)
        serializer.is_valid(raise_exception=True)
        #从serializer的validated_data['mobile'] 获取到mobile
        mobile = serializer.validated_data['mobile']
        #调用yunpian这个是自己写的类    apikey 是自己的  
        yun_pian = YunPian(APIKEY)
        code = self.gennerate_code()  #验证码 就是上面我们写的方法 生成一个四位数字
        sms_status = yun_pian.send_sms(code=code,mobile=mobile)  #然后  进行短信发送
         #这里是云片网 文档中告诉我们 成功 他返回了什么
        if sms_status['code'] != 0 :    #如果code 这个code跟我们上面的code不一样  这是发送万短信后的响应中的内容  如果code等于0 表示发送成功了  所以如果不等于0 就表示发送失败 我们就可以返回一个 400 给他
            return Response({
                'mobile':sms_status['msg']
            },status = status.HTTP_400_BAD_REQUEST)
        else:
            code_record = VerifyCode(code=code,mobile=mobile) #否则就是成功了 把code 和 mobile进行保存 
            code_record.save()  #保存后  用户进行验证
            return Response({
                'mobile':sms_status['msg']
            },status=status.HTTP_201_CREATED)

这里面主要的就是重写 create方法 里面的解释 我都写在注释中了 这样更容易看懂

你可能感兴趣的:(django-restful:serializers学习记录 和短信登录认证(三))