Spring Cloud Config对特殊字符加密的处理

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

Spring Cloud Config对特殊字符加密的处理

比如下面这样的情况:

$ 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的时候,正确的姿势应该是:

$ 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的例子,以供参考:

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(); 
} 

【本文为51CTO专栏作者“翟永超”的原创稿件,转载请通过51CTO联系作者获取授权】

戳这里,看该作者更多好文

原文 

http://zhuanlan.51cto.com/art/201806/576861.htm

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » Spring Cloud Config对特殊字符加密的处理

分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址