微服务springcloud—Config Server对称加密和非对称加密

矫情吗;* 2022-04-17 06:38 355阅读 0赞

配置内容的加解密

在Git仓库中明文存储配置属性的。很多场景下,对于某些敏感的配置内容(例如数据库账号、密码等),应当加密存储。

安装JCE

下载JCE并解压,按照其中的README.txt的说明安装。JCE的安装非常简单,其实就是将JDK/jre/lib/security目录中的两个jar文件替换为压缩包中的jar文件。

Config Server的加解密端点

Config Server提供了加密与解密的端点,分别是/encrypt与/decrypt。
可使用以下代码来加密明文:
curl $CONFIG_SERVER_URL/encrypt -d 想要加密的明文
使用以下代码来解密明文:
curl $CONFIG_SERVER_URL/decrypt -d 想要解密的密文

对称加密

1.复制项目microservice-config-server,将ArtifactId修改为microservice-config-server-encryption。
2.修改application.yml。

  1. encrypt:
  2. key:foo #设置对称密钥

3.测试
输入命令
curl http://localhost:8080/encrypt -d mysecret
可返回一段数据f3c094b8b2af01f525961b29d383c7985e5dd76226443a5fd14340c94c7b84e1,说明mysecret已被加密。
curl http://localhost:8080/decrypt -d {cipher}f3c094b8b2af01f525961b29d383c7985e5dd76226443a5fd14340c94c7b84e1,
可返回mysecret,说明能够正常解密。

存储加密的内容

加密后的文件,可使用{cipher}密文的形式存储。
1.准备一个配置文件,命名为encryption.yml。

  1. spring:
  2. datasource:
  3. username:dbuser
  4. password:'{cipher}{cipher}f3c094b8b2af01f525961b29d383c7985e5dd76226443a5fd14340c94c7b84e1'

2.使用http://localhost/encryption-default.yml可获得如下结果。
在这里插入图片描述

说明Config Server能自动解密配置内容。
一些场景下,想要让Config Server直接返回密文本身,而非解密后的内容,可设置spring.cloud.config.server.encrypt.enable=false,这可由Config Client自行解密。

非对称加密

1.复制项目microservice-config-server,将ArtifactId修改为microservice-config-server-encryption-rsa。
2.执行以下命令,并按照提示操作,即可创建一个Key Store。
keytool -genkeypair -alias mytestkey -keyalg RSA -dname “CN=Web Server,OU=Unit,O=Organization,L=City,S=State,C=US” -keypass changeme -keystore server.jks -storepass letmein
3.将生成的server.jks文件复制到项目的classpath下。
4.在application.yml中添加以下内容。

  1. encrypt:
  2. key-store:
  3. location: classpath:/server.jks #jks文件的路径
  4. password: letmein #storepass
  5. alias: mytestkey #alias
  6. secret: changeme #keypass

这样,使用以下命令:
curl http://localhost:8080/encrypt -d mysevret
在这里插入图片描述

相当于对称加密,非对称加密的安全性更高,但对称加密相对方便。读者可按照需求自行选择加密方案。

本文大部分内容转载自周立的《Spring Cloud与Docker微服务架构实战》

发表评论

表情:
评论列表 (有 0 条评论,355人围观)

还没有评论,来说两句吧...

相关阅读

    相关 加密算法-对称加密&对称加密

    加密算法是一种将明文转换为密文的算法,以保护数据的机密性和安全性。加密算法通常分为两种类型:对称加密算法和非对称加密算法。 1. 对称加密算法:指加密和解密使用相同密钥的算

    相关 对称加密对称加密

    对称加密与非对称加密 对称加密算法 简介 > 加密和解密用到的密钥是相同的,这种加密方式加密速度非常快,适合经常发送数据的场合。缺点是密钥的传输比较麻烦。常

    相关 对称加密对称加密

    非对称加密和对称加密在加密和解密过程、加密解密速度、传输的安全性上都有所不同,具体介绍如下: 1、加密和解密过程不同 对称加密过程和解密过程使用的同一个密钥,加密过程相当于