toytotp 玩具级的 TOTP 生成器开源项目

我要开发同款
匿名用户2019年08月12日
57阅读
开发技术Python
所属分类程序开发、安全相关框架
授权协议MIT

作品详情

toytotp是一个玩具级的 TOTP生成器。

TOTP代表基于时间的一次性密码。核心是HOTP算法。HOTP代表基于HMAC的一次性密码。以下是相关的RFC,这些算法的更多信息:

RFC2104:HMAC:Keyed-HashingforMessageAuthenticationRFC4226:HOTP:AnHMAC-BasedOne-TimePasswordAlgorithmRFC6238:TOTP:Time-BasedOne-TimePasswordAlgorithm

源码:

#!/usr/bin/python3importbase64importhmacimportstructimportsysimporttimedefhotp(secret,counter,digits=6,digest='sha1'):padding='='*((8-len(secret))%8)secret_bytes=base64.b32decode(secret.upper()+padding)counter_bytes=struct.pack(">Q",counter)mac=hmac.new(secret_bytes,counter_bytes,digest).digest()offset=mac[-1]&0x0ftruncated=struct.unpack('>L',mac[offset:offset+4])[0]&0x7fffffffreturnstr(truncated)[-digits:].rjust(digits,'0')deftotp(secret,interval=30):returnhotp(secret,int(time.time()/interval))if__name__=='__main__':forsecretinsys.argv[1:]:print(totp(secret.strip()))
声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论