示例#1
0
def send_sms_code():
    """发送短信验证码的后端接口"""
    """
    1.获取参数
        1.1 mobile: 手机号码, image_code:用户填写的图片验证码值, image_code_id: UUID编号
    2.校验参数
        2.1 非空判断
        2.2 手机号码格式校验
    3.逻辑处理
        3.1 根据image_code_id编号去redis中获取正确真实的图片验证码值
            3.1.1 真实的图片验证码有值:将值从redis数据库删除 [避免拿着这个值多次判断]
            3.1.2 真实的图片验证码没有值:图片验证码值过期了
        3.2 比对用户填写的图片验证码值 & 正确的图片验证码真实值
        3.3 不相等:返回错误状态码,提示图片验证码填写错误
        TODO: 提前判断手机号码是否注册过,数据库查询 [提高用户体验]
        3.4 发送短信验证码
        3.4.1 生成6位的随机短信验证码值
        3.4.2 调用CCP类发送短信验证码
        3.4.3 发送短信验证码成功后,保存6位的短信验证码值到redis数据库
    4.返回值
        4.1 发送短信验证码成功
    """
    # 1.1 mobile: 手机号码, image_code:用户填写的图片验证码值, image_code_id: UUID编号
    # 自动将json数据转换成字典
    param_dict = request.json
    mobile = param_dict.get("mobile")
    image_code = param_dict.get("image_code")
    image_code_id = param_dict.get("image_code_id")

    # 2.1 非空判断
    if not all([mobile, image_code, image_code_id]):

        # 参数不足 并且返回json格式数据
        # return jsonify({"errno": RET.PARAMERR, "errmsg": "参数不足"})
        return jsonify(errno=RET.PARAMERR, errmsg="参数不足")

    # 2.2 手机号码格式校验
    if not re.match(r"1[3546789][0-9]{9}", mobile):
        return jsonify(errno=RET.PARAMERR, errmsg="手机号码格式错误")

    # 3.1 根据image_code_id编号去redis中获取正确真实的图片验证码值
    try:
        real_image_code = redis_store.get("imageCode_%s" % image_code_id)
    except Exception as e:
        # 使用flask方式记录日志
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="查询图片验证码真实值数据异常")

    # 3.1.1 真实的图片验证码有值:将值从redis数据库删除 [避免拿着这个值多次判断]
    if real_image_code:
        redis_store.delete("imageCode_%s" % image_code_id)
    # 3.1.2 真实的图片验证码没有值:图片验证码值过期了
    else:
        return jsonify(errno=RET.NODATA, errmsg="图片验证码值过期了")

    # 3.2 比对用户填写的图片验证码值 & 正确的图片验证码真实值
    # 注意:忽略大小写 设置decode_responses=True
    if image_code.lower() != real_image_code.lower():
        # 4004 错误状态码,前端获取到后,需要重新生成一张图片
        # 3.3 不相等:返回错误状态码,提示图片验证码填写错误
        return jsonify(errno=RET.DATAERR, errmsg="图片验证码填写错误")

    # TODO: 提前判断手机号码是否注册过,数据库查询 [提高用户体验]
    try:
        user = User.query.filter(User.mobile == mobile).first()
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="查询用户对象异常")

    if user:
        # 用户已经注册
        return jsonify(errno=RET.DATAEXIST, errmsg="用户手机号码已经注册")

    # 3.4 发送短信验证码
    # 3.4.1 生成6位的随机短信验证码值
    real_sms_code = random.randint(0, 999999)
    # 不足6位前面补零
    real_sms_code = "%06d" % real_sms_code
    # 3.4.2 调用CCP类发送短信验证码
    ccp = CCP()
    try:
        result = ccp.send_template_sms(
            mobile, [real_sms_code, constants.SMS_CODE_REDIS_EXPIRES / 60], 1)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.THIRDERR, errmsg="云通信发送短信验证码异常")

    if result == -1:
        return jsonify(errno=RET.THIRDERR, errmsg="云通信发送短信验证码异常")

    # 3.4.3 发送短信验证码成功后,保存6位的短信验证码值到redis数据库[方便注册接口使用]
    try:
        redis_store.setex("SMS_%s" % mobile, constants.SMS_CODE_REDIS_EXPIRES,
                          real_sms_code)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="保存短信验证码值异常")

    # 4.1 发送短信验证码成功
    return jsonify(errno=RET.OK, errmsg="发送短信验证码成功")
示例#2
0
def send_sms_code():
    """点击发送短信验证码后端接口"""
    """
    1.获取参数
        1.1 手机号码mobile,用户填写的图片验证码值image_code,image_code_id全球唯一的UUID编号
    2.校验参数
        2.1 非空判断
        2.2 手机号码格式正则判断
    3.逻辑处理
        3.1 image_code_id编号去redis数据库取出图片验证码的真实值
            3.1.1 有值: 从redis数据库删除真实值(防止拿着相同的值多次验证)
            3.1.2 没有值:图片验证码值在redis中过期
        3.2 比较用户填写的图片验证码值和真实的验证码值是否一致
            TODO: 手机号码有了(用户是否已经注册的判断,用户体验最好),
            根据手机号码去查询用户是否有注册,有注册,不需要再注册,没有注册才去发送短信验证码
            一致:填写正确,生成6位的短信验证码值,发送短信验证码
            不一致:提示图片验证码填写错误
        3.3 将生成6位的短信验证码值 存储到redis数据库
    4.返回值
        4.1 发送短信验证码成功
    """
    #1.1 手机号码mobile,用户填写的图片验证码值image_code,image_code_id全球唯一的UUID编号
    # dict = json.loads(request.data) 能够将json字符串转换成dict
    # 能够获取前端发送过来的json数据,同时能够将json字符串转换成python的对象
    param_dict = request.json
    # 手机号码
    mobile = param_dict.get("mobile", "")
    # 用户填写的图片验证值
    image_code = param_dict.get("image_code", "")
    # uuid编号
    image_code_id = param_dict.get("image_code_id", "")

    #2.1 非空判断
    if not all([mobile, image_code, image_code_id]):
        current_app.logger.error("参数不足")
        # 返回json格式的错误信息
        return jsonify({"errno": RET.PARAMERR, "errmsg": "参数不足"})
    #2.2 手机号码格式正则判断
    if not re.match('1[3578][0-9]{9}', mobile):
        # 手机号码格式有问题
        current_app.logger.error("手机号码格式错误")
        return jsonify(errno=RET.PARAMERR, errmsg="手机号码格式错误")

    real_image_code = None
    try:
        # 3.1 image_code_id编号去redis数据库取出图片验证码的真实值
        real_image_code = redis_store.get("imageCodeId_%s" % image_code_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="查询图片验证码真实值异常")

    #3.1.1 有值: 从redis数据库删除真实值(防止拿着相同的值多次验证)
    if real_image_code:
        redis_store.delete("imageCodeId_%s" % image_code_id)
    # 3.1.2 没有值:图片验证码值在redis中过期
    else:
        return jsonify(errno=RET.NODATA, errmsg="图片验证码值在redis中过期")

    #3.2 比较用户填写的图片验证码值和真实的验证码值是否一致
    #细节1:全部转成小写
    #细节2:设置redis数据decode操作
    if real_image_code.lower() != image_code.lower():
        return jsonify(errno=RET.DATAERR, errmsg="图片验证码填写错误")
    """
        TODO: 手机号码有了(用户是否已经注册的判断,用户体验最好),
                根据手机号码去查询用户是否有注册,有注册,不需要再注册,没有注册才去发送短信验证码
    """
    try:
        user = User.query.filter(User.mobile == mobile).first()
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="查询用户数据异常")

    # 用户存在
    if user:
        return jsonify(errno=RET.DATAEXIST, errmsg="用户已经注册")

    #一致:填写正确,生成6位的短信验证码值,发送短信验证码
    # 生成6位的短信验证码值
    sms_code = random.randint(0, 999999)
    sms_code = "%06d" % sms_code
    # print(sms_code)

    try:
        ccp = CCP()
        result = ccp.send_template_sms(
            mobile, [sms_code, constants.SMS_CODE_REDIS_EXPIRES / 60], 1)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.THIRDERR, errmsg="云通讯发送短信验证码失败")

    # 发送短信验证失败
    if result != 0:
        return jsonify(errno=RET.THIRDERR, errmsg="云通讯发送短信验证码失败")

    #3.3 将生成6位的短信验证码值 存储到redis数据库
    try:
        redis_store.setex("SMS_CODE_%s" % mobile,
                          constants.SMS_CODE_REDIS_EXPIRES, sms_code)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="保存短信验证码到数据库异常")

    #4.返回值
    return jsonify(errno=RET.OK, errmsg="发送短信验证码成功")
示例#3
0
def send_sms_code():
    """
    /passport/sms_code
    传入参数:JSON格式:mobile,image_code,image_code_id(uuid)
    :return:errno,errmsg
    """
    param_dict = request.json
    mobile = param_dict.get("mobile")
    image_code = param_dict.get("image_code")
    image_code_id = param_dict.get("image_code_id")
    # 非空判断
    if not all([mobile, image_code, image_code_id]):
        return jsonify(errno=RET.PARAMERR, errmsg="参数不足")
    if not re.match(r'1[3-9]\d{9}', mobile):
        return jsonify(errno=RET.PARAMERR, errmsg="手机号码格式错误")
    # 根据image_code_id去redis中获取图形验证码的值
    try:
        real_image_code = redis_store.get("imageCode_%s" % image_code_id)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="数据异常")
    # 图形验证码有值,将值删除,避免多次重复验证
    if real_image_code:
        redis_store.delete("imageCode_%s" % image_code_id)
    else:
        # 没有值即代表过期
        return jsonify(errno=RET.NODATA, errmsg="图形验证码过期")
    # 将图片验证码进行对比
    if image_code.lower() != real_image_code.lower():
        return jsonify(errno=RET.DATAERR, errmsg="图片验证码输入错误")
    # 图片验证码输入正确,数据库查询电话号码有没有被注册过
    try:
        user = User.query.filter(User.mobile == mobile).first()
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DATAERR, errmsg="数据库查询异常")
    if user:
        return jsonify(errno=RET.DATAEXIST, errmsg="此号码已经注册过")
    # 发送短信
    # 生成随机的六位数
    real_sms_code = random.randint(0, 999999)
    real_sms_code = "%6d" % real_sms_code
    print(real_sms_code)
    # 调用CCP类发送短信验证码
    ccp = CCP()
    try:
        result = ccp.send_template_sms(
            mobile, [real_sms_code, constants.SMS_CODE_REDIS_EXPIRES / 60], 1)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.THIRDERR, errmsg="云通信发送短信验证码异常")

    if result == -1:
        return jsonify(errno=RET.THIRDERR, errmsg="云通信发送短信验证码异常")
    # 将短信验证码保存到数据库以备后续
    try:
        redis_store.setex("SMS_%s" % mobile, constants.SMS_CODE_REDIS_EXPIRES,
                          real_sms_code)
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg="保存短信验证码值异常")

    # 4.1 发送短信验证码成功
    return jsonify(errno=RET.OK, errmsg="发送短信验证码成功")
示例#4
0
def send_sms():
    """
    1. 接受参数并判断是否有值
    2. 校验手机号是否正确
    3. 通过传入的图片编码去redis中查询真是的图片验证码内容
    4. 进行验证码内容的比对
    5. 生成发送短信的内容并发送短信
    6. redis中保存短信验证码内容
    7. 返回发送成功的响应
    :return:
    """
    # 1. 接受参数并判断是否有值
    # 渠道请求值中的内容
    param_dict = request.json
    mobile = param_dict.get('mobile')
    image_code = param_dict.get('image_code')
    image_code_id = param_dict.get('image_code_id')

    if not all([mobile, image_code, image_code_id]):
        # 参数不全
        return jsonify(errno=RET.PARAMERR, errmsg='参数不全')

    # 2. 校验手机号是否正确
    if not re.match(r'^1[3-9]\d{9}$', mobile):
        # 提示手机号不正确
        return jsonify(errno=RET.DATAERR, errmsg='手机号不正确')

    # 3. 通过传入的图片编码去redis中查询真实的图片验证码内容
    try:
        real_image_code = redis_store.get('ImageCode_' + image_code_id)
        # 如果能够取出来值,则删除redis中缓存的内容
        if real_image_code:
            real_image_code = real_image_code.decode()
            redis_store.delete('ImageCode_' + image_code_id)
    except Exception as e:
        current_app.logger.error(e)
        # 获取图片验证码失败
        return jsonify(errno=RET.DBERR, errmsg='获取图片验证码失败')

    # 3.1 判断验证码是否已过期
    if not real_image_code:
        # 验证码已过期
        return jsonify(errno=RET.NODATA, errmsg='验证码已过期')

    # 4. 进行验证码内容的比对
    if image_code.lower() != real_image_code.lower():
        # 验证码输入错误
        return jsonify(errno=RET.DATAERR, errmsg='验证码输入错误')

    # 4.1 校验该手机是否已经注册
    try:
        user = User.query.filter_by(mobile=mobile).first()
    except Exception as e:
        current_app.logger.error(e)
        return jsonify(errno=RET.DBERR, errmsg='数据库查询错误')
    if user:
        # 该手机已被注册
        return jsonify(errno=RET.DATAEXIST, errmsg='该手机已被注册')

    # 5. 生成发送短信的内容并发送短信
    result = random.randint(0, 999999)
    sms_code = "%06d" % result
    current_app.logger.debug("短信验证码的内容: %s" % sms_code)
    ccp = CCP()
    result = ccp.send_template_sms(mobile, [sms_code, constants.SMS_CODE_REDIS_EXPIRES/60], "1")
    if result != 0:
        # 发送短信失败
        return jsonify(errno=RET.THIRDERR, errmsg='发送短信失败')

    # 6. redis中保存短信验证码内容
    try:
        redis_store.set('SMS_' + mobile, sms_code, constants.SMS_CODE_REDIS_EXPIRES)
    except Exception as e:
        current_app.logger.error(e)
        # 保存短信验证码失败
        return jsonify(errno=RET.DBERR, errmsg='保存短信验证码失败')

    # 7. 返回发送成功的响应
    return jsonify(errno=RET.OK, errmsg='发送成功')