spring boot 接口参数解密和返回值加密
开发背景
虽然使用 HTTPS 已经可以基本保证传输数据的安全性,但是很多国企、医疗、股票项目等仍然要求对接口数据进行自行加密,作者最近就遇到了,是支付宝对接国家医保的接口时,医保接口要求进行接口加密。
所以鉴于这个需求的存在,作者也找过现在的一些接口加密组件,发现都是3.4年前就已经停止更新了,并且不接受 pr 也不回复 issue 了,用起来也是功能简陋配置复杂,所以就开发了一套全新的组件。
作者对接口加密的各种需求了解的并不是很多,如果在使用中有功能缺失,欢迎来 Github 提 issue 或者 pr ❤️。
简介
SecureApi 是一款接口参数和返回值加解密工具,高性能、轻量化,无任何外部依赖;
spring boot 场景启动器设计(支持spring boot2和3),完全自动化,支持 param、body 参数(暂不支持 path 参数),用户无需关心加密解密和密钥匹配过程;
配置灵活,配置文件支持 yml 和 bean 方式,支持注解、url正则进行接口匹配,支持 AES、SM4、RSA 等多种加密方式,支持 DH 前后端密钥协商方式。
用户增量趋势
此组件发布已经一两年了,发现有那么多用户,才重新整理了命名、仓库和文档
==本篇只是先体验功能,使用请看官方文档:== https://doc.xuyijie.icu/secure-api-doc/
==Github地址:== https://github.com/BubblingXuYijie/secure-api-spring-boot
==Gitee地址(非主要,issue还是集中在Github比较好,大家都可以看到)== https://gitee.com/BubblingXuYijie/secure-api-spring-boot
一些问题你们会在文档
中或者Github的 issue 里找到答案,如果你不知道前端如何配合,那么文档里有你想要的东西
安装
环境要求:
- jdk8+(spring boot 3 请使用 jdk17+)
- Maven/Gradle
- spring boot 2+(spring boot 3 请引入 SecureApi 的 3.0.0+ 版本)
Maven
1 | <!-- https://mvnrepository.com/artifact/icu.xuyijie/secure-api-spring-boot-starter --> |
Gradle
1 | // spring boot 3 请引入 3.1.1 版本 |
配置
有两种配置方法,
yml
和Bean
方式,看你喜欢哪一个,如果是对安全性要求较高,建议使用Bean
方式动态设置密钥,而不是写在yml
里。
yml 方式
下面是 yml 的完整配置,有些配置项是可选的,在注解中均已解释
1 | secure-api: |
Bean 方式
注意,一旦使用了
Bean
方式来配置,yml
里的配置项都将失效
1 | import icu.xuyijie.secureapi.cipher.CipherAlgorithmEnum; |
试一下
好了各位大佬们,到了这里,配置以及完成,接下来可以进行效果体验了,后面有时间会提供前后端的 demo。
==本篇只是先体验功能,请务必和我的代码相同,不然也许你会遇到一些问题,代码里使用的注解等看文档会介绍,可以解决你的疑惑。==
启动项目
SecureApi的
enable
设置为true
时,控制台会打印以下信息,代表开启接口加解密功能,我这里没有指定 key ,所以组件为我自动生成了,然后你可以把密钥设置到前端或者和前端进行密钥协商以追求更安全的传输。
建议测试的时候使用
CipherUtils
手动设置密钥,可以指定seed
保证每次生成的密钥相同,更加方便。
返回值加密
前面我们没有配置url匹配,需要在接口上或者接口所在类上添加
@EncryptApi
注解,即可实现返回值加密
可以看到由于我开启了日志打印功能,控制台打印出一些信息
接口返回的是一个 json 字符串,然后前端使用对应密钥解密这个字符串(注意这是个json字符串,前端处理时应该去除前后两端引号)就可以拿到
{"code":200,"message":"哈哈哈","data":null}
这样的对象了
参数解密
body 参数解密
组件可以对json参数体进行解密,这次我们传入上一步中加密的返回值,看一看解密结果,接口需要添加
@DecryptApi
注解,这样这个接口既会解密参数,也会加密返回值
使用
Postman
发送密文body参数
可以看到密文参数正常解密为
{"code":200,"message":"哈哈哈","data":null}
,返回值也成功加密了
param和form-data参数解密
这一次我们整复杂一点,各种类型的参数都整上,没有开启url匹配,我们要给字段加上
@DecryptParam
注解,注意@DecryptParam
不能和@RequestParam
同时使用,@DecryptParam
已经替代了后者功能。
实体类本身不需要加注解,要加在里面的字段上,注意,没有加注解的字段不会解密(配置了url匹配的话,加不加注解全部字段都会解密)
发送请求,请求中这些密文都是我提前用代码生成好的(注意,param里的密文要是url safe的),这些参数放在 param 里或者放在 form-data 里发送都是可以的
成功解密加了注解的参数,没有加注解和为null的参数不解密
总结
==本篇只是先体验功能,使用请看官方文档:== https://doc.xuyijie.icu/secure-api-doc/
==Github地址:== https://github.com/BubblingXuYijie/secure-api-spring-boot
==Gitee地址(非主要,issue还是集中在Github比较好,大家都可以看到)== https://gitee.com/BubblingXuYijie/secure-api-spring-boot
一些问题你们会在文档
中或者Github的 issue 里找到答案,如果你不知道前端如何配合,那么文档里有你想要的东西