Flask发送验证码逻辑

发送短信验证码

  1. 安装第三方库
pip install ronglian_sms_sdk
  1. 还要设置一个配置文件settings/config.py写入代码
from settings.secret import SecretConfig

class DefaultConfig(SecretConfig):
    """
    默认配置项
    """
    SECRET_KEY = 'haoiehteasdsd'
    SQLALCHEMY_DATABASE_URI = ''
    SQLALCHEMY_TRACK_MODIFICATIONS = False
    SQLALCHEMY_ECHO = True

class DevConfig(DefaultConfig):
    """
    开发阶段配置项
    """
    SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:222222@127.0.0.1:3306/news'
  1. 创建一个utils/SmsTools.py文件写入代码
from ronglian_sms_sdk import SmsSDK
from flask import current_app
import json, redis


class SmsTool():
    """
    发送短信类
    """

    def __init__(self):
        accId = current_app.config.get('RL_ACC_ID')  # 主账户ID
        accToken = current_app.config.get('RL_ACC_TOKEN')  # 账户授权令牌
        appId = current_app.config.get('RL_APP_ID')  # 默认
        # 实例化SmsSDK
        self.sdk = SmsSDK(accId, accToken, appId)

        host = current_app.config.get('REDIS_HOST')
        port = current_app.config.get('REDIS_PORT')
        self.red = redis.Redis(host=host, port=port)

    def send(self, phone, code):
        """

        :param phone:
        :param code:
        :return:
        """

        tid = current_app.config.get('RL_TID')
        # 有效期
        t = current_app.config.get('SMS_TIME')
        datas = (code, t)

        # 存储redis
        self.red.set(phone, code, ex=t * 60)

        # 发送短信验证码
        rs = self.sdk.sendMessage(tid, phone, datas)  # 返回的是JSON字符串
        rs_data = json.loads(rs)
        if rs_data['statusCode'] == '000000':
            return True
        return False


# if __name__ == '__main__':
#     # 开启上下文换进
#     from app import app
#
#     with app.app_context():
#         s = SmsTool()
#         rs = s.send('17559511990', '6666')
#         print(rs)
  1. 直接调用即可

class SmsCodeView(Resource):
    def get(self):
        req = reqparse.RequestParser()
        req.add_argument('mobile')
        args = req.parse_args()

        sms_code = random.randint(10, 99)
        s = SmsTool()
        ser = s.send(args['mobile'], sms_code)

        if not ser:
            return jsonify({'code': 400, 'msg': '发送失败'})

        return jsonify({'code': 200, 'msg': '已发送请注意查收'})


api.add_resource(SmsCodeView, '/sms')

token的生成

  1. 封装一个生成token的方法
import time
import jwt
from flask import current_app


class JwtTool():
    def create(self, payload, ex=3600):
        """
        生成jwt
        :param payload:
        :return:
        """
        payload['exp'] = int(time.time()) + ex
        print(payload)
        secret_key = current_app.config.get('SECRET_KEY')
        token = jwt.encode(payload, key=secret_key, algorithm='HS256')
        print(token)
        return token

    def valid(self, token):

        secret_key = current_app.config.get('SECRET_KEY')
        try:
            time.sleep(2)
            payload = jwt.decode(token, secret_key, algorithms='HS256')
            print(payload)
            return payload
        except Exception as e:
            print(e)
            return False


if __name__ == '__main__':
    from app import app

    with app.app_context():
        j = JwtTool()
        token_jwt = j.create({'aaa': 'bbb'})

        j.valid(token_jwt)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值