对于目前众多的验证码解决方案来说,这个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)
相关文章:

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。 Python以简洁和强大的生态系统着称,C 则以高性能和底层控制能力闻名。

2小时内可以学会Python的基本编程概念和技能。1.学习变量和数据类型,2.掌握控制流(条件语句和循环),3.理解函数的定义和使用,4.通过简单示例和代码片段快速上手Python编程。

Python在web开发、数据科学、机器学习、自动化和脚本编写等领域有广泛应用。1)在web开发中,Django和Flask框架简化了开发过程。2)数据科学和机器学习领域,NumPy、Pandas、Scikit-learn和TensorFlow库提供了强大支持。3)自动化和脚本编写方面,Python适用于自动化测试和系统管理等任务。

两小时内可以学到Python的基础知识。1.学习变量和数据类型,2.掌握控制结构如if语句和循环,3.了解函数的定义和使用。这些将帮助你开始编写简单的Python程序。

如何在10小时内教计算机小白编程基础?如果你只有10个小时来教计算机小白一些编程知识,你会选择教些什么�...

使用FiddlerEverywhere进行中间人读取时如何避免被检测到当你使用FiddlerEverywhere...

Python3.6环境下加载Pickle文件报错:ModuleNotFoundError:Nomodulenamed...

如何解决jieba分词在景区评论分析中的问题?当我们在进行景区评论分析时,往往会使用jieba分词工具来处理文�...


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3 Linux新版
SublimeText3 Linux最新版

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

Atom编辑器mac版下载
最流行的的开源编辑器

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。