1.图片验证码
防止频繁调用短信接口,导致公司大量的损失。流程是客户端生成uuid唯一标识向接口,发起请求,在接口中生成图片验证码,将uuid作为key,验证码作为Value储存在redis中。以流的方式返回给前端
生成图片验证码代码
# 生成图形验证码
@user_blue.route("/getcode", methods=["GET"])
def getcode():
img_code = "".join(random.sample(string.digits+string.ascii_letters, 4)) # 随机获取字符串+数字的的4个字符
cap = ImageCaptcha() # 生成图形验证码
img = cap.generate(img_code) # 使用生成图片
# 从页面中获取uuid作为redis key
uuid = str(request.args.get("uuid"))
# 写入redis
r.str_add(uuid, str(img_code), 60)
return send_file(img, 'image/png')
短信验证码
判断图片和手机中是否输入,正则验证手机号有效性,根据uuid去redis中查询图片验证码,同时转成大写或者小写进行对比,如果通过验证手机号一分钟内没有发过,如果没有调用容联云短信平台发送,成功后存入redis,key,mobile,value验证码,删除图片验证码
3.注册登录流程
获取手机号,短信验证码,通过手机号去redis中短信验证码,验证码对比,通过删除redis中的短信验证码,如果相同查询数据库user表,如果存在返回user信息,如果不存在注册,获取到用户信息,用jwt生成token返回给客户端,存储在localStotage中