java加密去掉特殊字符_java相关:Spring Cloud Config对特殊字符加密处理的方法详解...

java相关:Spring Cloud Config对特殊字符加密处理的方法详解

发布于 2020-6-2|

复制链接

摘记: 前言之前写过一篇关于配置中心对配置内容加密解密的介绍:《Spring Cloud构建微服务架构:分布式配置中心(加 ..

前言之前写过一篇关于配置中心对配置内容加密解密的介绍:《Spring Cloud构建微服务架构:分布式配置中心(加密解密) 》。在这篇文章中,存在一个问题:当被加密内容包含一些诸如=、+这些特殊字符的时候,使用上篇文章中提到的类似这样的命令curl localhost:7001/encrypt -d去加密和解密的时候,会发现特殊字符丢失的情况。比如下面这样的情况:

```plain

$ curl localhost:7001/encrypt -d eF34+5edo=

a34c76c4ddab706fbcae0848639a8e0ed9d612b0035030542c98997e084a7427

$ curl localhost:7001/decrypt -d a34c76c4ddab706fbcae0848639a8e0ed9d612b0035030542c98997e084a7427

eF34 5edo

```

可以看到,经过加密解密之后,又一些特殊字符丢失了。由于之前在这里也小坑了一下,所以抽空写出来分享一下,给遇到同样问题的朋友,希望对您有帮助。问题原因与处理方法其实关于这个问题的原因在官方文档中是有具体说明的,只能怪自己太过粗心了,具体如下:

If you are testing like this with curl, then use --data-urlencode (instead of -d) or set an explicit Content-Type: text/plain to make sure curl encodes the data correctly when there are special characters (‘+' is particularly tricky).

所以,在使用curl的时候,正确的姿势应该是:

```plain

$ curl localhost:7001/encrypt -H 'Content-Type:text/plain' --data-urlencode "eF34+5edo="

335e618a02a0ff3dc1377321885f484fb2c19a499423ee7776755b875997b033

$ curl localhost:7001/decrypt -H 'Content-Type:text/plain' --data-urlencode "335e618a02a0ff3dc1377321885f484fb2c19a499423ee7776755b875997b033"

eF34+5edo=

```

那么,如果我们自己写工具来加密解密的时候怎么玩呢?下面举个OkHttp的例子,以供参考:

```java

private String encrypt(String value) {

String url = "http://localhost:7001/encrypt";

Request request = new Request.Builder()

.url(url)

.post(RequestBody.create(MediaType.parse("text/plain"), value.getBytes()))

.build();

Call call = okHttpClient.newCall(request);

Response response = call.execute();

ResponseBody responseBody = response.body();

return responseBody.string();

}

private String decrypt(String value) {

String url = "http://localhost:7001/decrypt";

Request request = new Request.Builder()

.url(url)

.post(RequestBody.create(MediaType.parse("text/plain"), value.getBytes()))

.build();

Call call = okHttpClient.newCall(request);

Response response = call.execute();

ResponseBody responseBody = response.body();

return responseBody.string();

}

```

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值