中间还有重要的一步 没有写 就是 什么时候调用了 发送短信 这个方法
这几篇写的有些乱
首先写 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方法 里面的解释 我都写在注释中了 这样更容易看懂
网友评论