导出Google身份校验器otp密钥迁移到web

导出Google身份校验器otp密钥迁移到web

背景:

公司的堡垒机需要使用30s有效期otp动态密码做二次登录。实现某些情况下,同事可通过web,在规定的有效期内可获取otp二次授权密码

otp:一次性密码(英语:OneTimePassword,简称OTP),通过密钥和时间hash得到固定长度的密码

Google身份校验器otpt密钥导出

Google身份校验器导出二维码,通过解析二维码可得到otpauth-migration://offline?data=XXXX的一串数据。

解析otpauth-migration数据,我用到了extract_otp_secrets的python项目,解析后,拿到Secret

在这里插入图片描述

项目代码

已上传GitHub 项目代码,具体代码可参考

otp密码加解密

otp密码比较敏感,既然要上传GitHub,需做好加密
pom中引入jasypt-maven-plugin插件,方便加解密

# 加密
mvn jasypt:encrypt-value -Djasypt.encryptor.password="password" -Djasypt.plugin.value="value"
解密
mvn jasypt:decrypt-value -Djasypt.encryptor.password="password" -Djasypt.plugin.value="ENC(47GYBJezlwnAkSUsVpoJhN2PmUSxhy2+RzakDWkjUZyZFCyZc676w3znplmuf/0F)"

加密把密文写入配置文件中,密钥通过启动JVM参数传入

接口列表

  • port:/ :获取otp

有效期内返回

otp=987728 ,expires later :7second!!

在这里插入图片描述

非有效期

在这里插入图片描述

  • port:/update/{minutes} :更新密码有效期

技术列表

1 使用otp-java生成otp密码

<dependency>
    <groupId>com.github.bastiaanjansen</groupId>
    <artifactId>otp-java</artifactId>
    <version>1.3.2</version>
</dependency>

2 使用jasypt加密otp密码

<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>3.0.5</version>
</dependency>

Docker

使用docker部署

# 构建image
docker build -t myotp:v1.1.19 .

# 启动 传入密钥
docker run -d -p 8090:8090 -e JAVA_ARGS='-Djasypt.encryptor.password=passwd'   --name otp myotp:v1.1.19 

开源项目地址

jaspty

otp-java

extract_otp_secrets

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值