天翼開放平臺免費短信驗證碼接口使用實例
對于目前眾多的驗證碼解決方案來說,這個API有著中國電信這個重量級的運營商為靠山,應(yīng)該是比較靠譜的了,而且還是免費的。詳細情況請參閱:http://open.189.cn
使用方式:
#定義app_id和app_secret
r = RandCode('app_id', 'app_secret')
#支持平臺的兩種接口方式
#方式1:自定義接收驗證碼的回調(diào)URL
r.send('phone number', 'http://yourdomain/rand_code.php', '3')
#方式2:自定義驗證碼內(nèi)容
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)
相關(guān)文章
python3.7安裝matplotlib失敗問題的完美解決方法
由于學(xué)習(xí)需要安裝matplotlib庫,閱讀網(wǎng)上教程后一直出現(xiàn)各種各樣的錯誤,下面這篇文章主要給大家介紹了關(guān)于python3.7安裝matplotlib失敗問題的完美解決方法,需要的朋友可以參考下2022-07-07Python中flatten( ),matrix.A用法說明
這篇文章主要介紹了Python中flatten( ),matrix.A用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07TensorFlow 實戰(zhàn)之實現(xiàn)卷積神經(jīng)網(wǎng)絡(luò)的實例講解
下面小編就為大家分享一篇TensorFlow 實戰(zhàn)之實現(xiàn)卷積神經(jīng)網(wǎng)絡(luò)的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02