最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

天翼开放平台免费短信验证码接口使用实例

来源:懂视网 责编:小采 时间:2020-11-27 14:38:47
文档

天翼开放平台免费短信验证码接口使用实例

天翼开放平台免费短信验证码接口使用实例:对于目前众多的验证码解决方案来说,这个API有着中国电信这个重量级的运营商为靠山,应该是比较靠谱的了,而且还是免费的。使用方式:#定义app_id和app_secretr = RandCode('app_id', 'app_secret')#支持平台的两种接口方式
推荐度:
导读天翼开放平台免费短信验证码接口使用实例:对于目前众多的验证码解决方案来说,这个API有着中国电信这个重量级的运营商为靠山,应该是比较靠谱的了,而且还是免费的。使用方式:#定义app_id和app_secretr = RandCode('app_id', 'app_secret')#支持平台的两种接口方式

对于目前众多的验证码解决方案来说,这个API有着中国电信这个重量级的运营商为靠山,应该是比较靠谱的了,而且还是免费的。

使用方式:
#定义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)

相关文章:

基于PHP实现短信验证码接口

短信验证码接口(容联运通讯)

PHP集成发送手机短信验证码、语音验证码接口函数及使用方法

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

天翼开放平台免费短信验证码接口使用实例

天翼开放平台免费短信验证码接口使用实例:对于目前众多的验证码解决方案来说,这个API有着中国电信这个重量级的运营商为靠山,应该是比较靠谱的了,而且还是免费的。使用方式:#定义app_id和app_secretr = RandCode('app_id', 'app_secret')#支持平台的两种接口方式
推荐度:
标签: 使用 接口 API
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top