天翼开放平台免费短信验证码接口使用实例
发布时间:2023-10-13 06:41:55
对于目前众多的验证码解决方案来说,这个API有着中国电信这个重量级的运营商为靠山,应该是比较靠谱的了,而且还是免费的。详细情况请参阅:http://open.189.cn
使用方式:
#定义app_id和app_secret
r = RandCode('app_id', 'app_secret')
#支持平台的两种接口方式
#方式1:自定义接收验证码的回调URL
r.send('phone number', 'http://yourdomain/rand_code.php', '3')
#方式2:自定义验证码内容
r.send_sms('phone number', 189189)
#!/usr/bin/env python
# coding: utf-8
from time import strftime, localtime
import urllib, urllib2, json
import hmac, hashlib
class RandCode(object):
APP_ID = ''
APP_SECRET = ''
ACCESS_TOKEN = ''
RANDCODE_TOKEN = ''
TOKEN_API = 'https://oauth.api.189.cn/emp/oauth2/v2/access_token'
RANDCODE_TOKEN_API = 'http://api.189.cn/v2/dm/randcode/token'
RANDCODE_SEND_API = 'http://api.189.cn/v2/dm/randcode/send'
RANDCODE_SENDSMS_API = 'http://api.189.cn/v2/dm/randcode/sendSms'
def __init__(self, app_id='', app_secret='', access_token=''):
self.APP_ID = app_id or RandCode.APP_ID
self.APP_SECRET = app_secret or RandCode.APP_SECRET
self.ACCESS_TOKEN = access_token or self.__fetch_access_token()
self.RANDCODE_TOKEN = self.__fetch_randcode_token()
def send(self, phone, url, exp_time):
result = False
if self.ACCESS_TOKEN and self.RANDCODE_TOKEN:
data = {
'app_id':self.APP_ID,
'access_token':self.ACCESS_TOKEN,
'token':self.RANDCODE_TOKEN,
'phone':phone,
'url':url,
'exp_time':exp_time,
'timestamp':self.__date_time(),
}
data = self.__build_request_string(data)
data = self.__data_sign(data)
if data:
res = self.__request_data('post', data, self.RANDCODE_SEND_API)
json_data = json.loads(res)
if json_data['res_code'] == 0:
result = True
return result
def send_sms(self, phone, randcode, exp_time='2'):
result = False
if self.ACCESS_TOKEN and self.RANDCODE_TOKEN:
data = {
'app_id':self.APP_ID,
'access_token':self.ACCESS_TOKEN,
'token':self.RANDCODE_TOKEN,
'phone':phone,
'randcode':str(randcode),
'exp_time':exp_time,
'timestamp':self.__date_time(),
}
data = self.__build_request_string(data)
data = self.__data_sign(data)
if data:
res = self.__request_data('post', data, self.RANDCODE_SENDSMS_API)
json_data = json.loads(res)
if json_data['res_code'] == 0:
result = True
return result
pass
def __request_data(self, method, data, url):
if isinstance(data, dict):
data = urllib.urlencode(data)
if method == 'post':
req = urllib2.Request(url, data)
else:
url = '%s?%s' % (url, data)
req = urllib2.Request(url)
return urllib2.urlopen(req).read()
def __fetch_access_token(self):
access_token = self.ACCESS_TOKEN
if access_token == '':
data = {
'grant_type':'client_credentials',
'app_id':self.APP_ID,
'app_secret':self.APP_SECRET,
}
res = self.__request_data('post', data, self.TOKEN_API)
json_data = json.loads(res)
if json_data['res_code'] == '0':
access_token = json_data['access_token']
else:
raise ValueError(json_data['res_message'])
return access_token
def __fetch_randcode_token(self):
result = ''
if self.ACCESS_TOKEN != '':
data = {
'app_id':self.APP_ID,
'access_token':self.ACCESS_TOKEN,
'timestamp':self.__date_time(),
}
data = self.__build_request_string(data)
data = self.__data_sign(data)
if data:
res = self.__request_data('get', data, self.RANDCODE_TOKEN_API)
json_data = json.loads(res)
if json_data['res_code'] == 0:
result = json_data['token']
else:
raise ValueError(json_data['res_message'])
return result
def __data_sign(self, data):
result = ''
if data:
if isinstance(data, dict):
data = self.__build_request_string(data)
sign = hmac.new(self.APP_SECRET, urllib.urlencode(data), hashlib.sha1).digest()
elif isinstance(data, unicode):
sign = hmac.new(self.APP_SECRET, data, hashlib.sha1).digest()
if data:
result = "%s&sign=%s" % ( data, urllib.quote(sign.encode('base64').strip()) )
return result
def __build_request_string(self, dict):
keys = dict.keys()
keys.sort()
return '&'.join([ key + "=" + dict[key] for key in keys ])
def __date_time(self):
return strftime("%Y-%m-%d %H:%M:%S", localtime())
if __name__ == '__main__':
r = RandCode('app_id', 'app_secret')
r.send('phone number', 'http://yourdomain/rand_code.php', '3')
r.send_sms('phone number', 189189)


猜你喜欢
- 一、HandlerSocket是什么?HandlerSocket是akira higuchi写的一个MySQL的插件。以MySQL Daem
- 这些标记告诉预处理器,它们包含代码,并且应对它们作出处理。与 CGI 非常相似,这些代码在服务器上运行,并返回一些内容,这些内容表现为发回给
- 1、说明curses提供了内置颜色可以让我们自定义前后背景。在使用彩色模式之前我们需要先使用使用curses.start_corlor()进
- 函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。注意其中:map和filter返回一个惰性序列,可
- 1. vue打包后font-awesome字体失效解决方案:2. 打包后图片资源失效解决方案:针对html中引用的图片针对css添加的背景中
- 首先我们的目标是这样子的:那么他有什么成分呢?有圣诞树的本体、大小蝴蝶结、星星、圣诞帽和袜子。首先我们来画圣诞树的本体。1. 圣诞树的本体圣
- flask响应错误处理及errorhandler应用@app.errorhandler(404)def page_not_found(err
- 一个非常实用的小方法试想一下,Django中如果我们想对保存进数据库的数据做校验,有哪些实现的方法?我们可以在view中去处理,每当view
- 前言前面安装过mysql5.6,时隔三个月,开发那边反馈需要在MySQL中处理JSON类型的数据,查看文档,JSON是在5.7支持的新特性。
- 为什么要实现分页?在大部分网站中分页的功能都是必要的,尤其是在后台管理中分页更是不可或缺分页能带给用户更好的体验,也能减轻服务器的压力对于分
- 前言正则表达式是对字符串提取的一套规则,我们把这个规则用正则里面的特定语法表达出来,去匹配满足这个规则的字符串。正则表达式具有通用型,不仅p
- 下文要实现的可视化大屏内容:需要在地图上将我司船舶的轨迹展示出来。听起来很简单,一开始我也是这样想的。通过一些BI工具应该可以轻松实现,比如
- 前言虽然Python的标准库中 urllib2 模块已经包含了平常我们使用的大多数功能,但是它的 API 使用起来让人感觉不太好,而 Req
- 一、网络结构的可视化我们训练神经网络时,除了随着step或者epoch观察损失函数的走势,从而建立对目前网络优化的基本认知外,也可以通过一些
- 怎么用javascript进行拖拽本文译自:http://www.webreference.com/programming/javascri
- stylus及stylus-loader版本问题安装下面指定本版就解决了:"stylus": "^0.54.7
- 本文实例讲述了Vue常用传值方式、父传子、子传父及非父子。分享给大家供大家参考,具体如下:父组件向子组件传值是利用props子组件中的注意事
- 分离结构与表现的另一个重要方面是使用语义化的标记来构造文档内容。一个 XHTML 元素的存在就意味被标记内容的那部分有相应的结构化的意义,没
- 1、从半年以前要“去中心化”开始,豆瓣作了不少大的调整,重要的是上线了很多的新功能。同城、日记、相册、音乐试听、等等。2、一个多月来,豆瓣上
- 目录1 标准化2 归一化3 正则化4 离散化5 白化 机器