SDK参考(新版)
云通讯平台为开发者提供多语言SDK,让您可以轻松地选择你熟悉的编程语言来体验。
短信服务新版SDK源码已经托管至开源平台Github
您可以通过SDK调用云通讯短信API。
您可以通过以下方式获得相关指引和SDK 源码:
如果使用的时python语言的话,SDK相关文件找我要
将SDK文件放入到项目的公共方法下的工具utils中
用户注册(后端)
用户获取短信验证码代码
class User_SMS(Resource):
"""
发送验证码的短信,
"""
def get(self):
mobile=request.args.get('mobile')
#随机验证码
code=random.randint(1000,9999)
result=send_message(tid='1',mobile = mobile,datas = (code,'1'))
#result时json格式的字符串,需要转化为字典
result=json.loads(result)
# 往响应中添加手机号
result['mobile'] = mobile
#短信验证码发送成功之后,还需要将验证码fangdaoredis数据库中,以便于再次使用
return result
Flask-limiter限流
Flask-Limiter为flask路由提供了速率限制的特性。它支持使用内存、redis或者memcache作为存储环境的后端实现。
注意:
1、发短信不能重复发
2、短信验证码内容需要保存起来:redis
安装:
pip install flask-limiter
目录结构:
limiter.py文件:
from flask_limiter import Limiter
from flask_limiter.util import get_remote_address
#创建限流器
limiter=Limiter(key_func=get_remote_address)
constants.py文件
#定义限流器常量
#根据手机号码限制短信验证码发送的频次
LIMIT_SMS_CODE_BY_MOBILE='1/minute'
#根据客户端ip限制短信验证码发送的频次
LIMIT_SMS_CODE_BY_IP='30/hour'
#短信验证码存放到redis数据库中的时效为
SMS_CODE_EXPIRES=20*60
资源下的__init__.py文件
#shop目录中放置项目的蓝图
from flask import Flask
from settings.default import map_config
from shop.rescoures.user import user_bp
from shop.rescoures.order import order_bp
def app_config(config_type):
app=Flask(__name__)
app.config.from_object(map_config.get(config_type))
#初始化SQLALchemy
from comment.models import db
db.init_app(app)
#初始化限流器
from comment.utils.limiter import limiter
limiter.init_app(app)
# 加载日志处理的工具
from comment.utils.loggings import create_logger
create_logger(app)
#注册蓝图
app.register_blueprint(user_bp,url_prefix='/user')
app.register_blueprint(order_bp,url_prefix='/order')
return app
user_resoures.py
#定义蓝图视图
from flask_restful import Resource
#加载User模型类
from flask import current_app,request
from comment.utils.SendMessage import send_message
import random
import json
from comment.utils.limiter import limiter
from shop.rescoures.user import constants
from flask_limiter.util import get_remote_address
#定义资源
class Shoping(Resource):
def get(self):
current_app.logger.info('我的测试日志')
#这里的代码可能会用到User模型类
return {"hello":"test"}
class User_SMS(Resource):
"""
发送验证码的短信,
"""
error_message='TO many requests.'
decorators = [
#3个参数:参数1:限流的速率;参数2:key_func;参数3:如果超出限制之后的信息
limiter.limit(constants.LIMIT_SMS_CODE_BY_MOBILE,
key_func=lambda :request.args['phone'],
error_message=error_message),
limiter.limit(constants.LIMIT_SMS_CODE_BY_MOBILE,
key_func=get_remote_address,
error_message=error_message),
]
def get(self):
mobile=request.args.get('mobile')
#随机验证码
code=random.randint(1000,9999)
result=send_message(tid='1',mobile = mobile,datas = (code,'1'))
#result时json格式的字符串,需要转化为字典
result=json.loads(result)
# 往响应中添加手机号
result['mobile'] = mobile
return result
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/74103.html