春云配置对特殊字符加密处理的方法详解

  

  

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

  

比如下面这样的情况:

        旋度localhost: 7001美元/加密- d eF34 + 5江户=a34c76c4ddab706fbcae0848639a8e0ed9d612b0035030542c98997e084a7427   $ curl localhost: 7001/解密- d a34c76c4ddab706fbcae0848639a8e0ed9d612b0035030542c98997e084a7427   eF34 5江户      

可以看的到,经过加密解密之后,又一些特殊字符丢失了。由于之前在这里也小坑了一下,所以抽空写出来分享一下,给遇到同样问题的朋友,希望对您有帮助。

  

  

其实关于这个问题的原因在官方文档中是有具体说明的,只能怪自己太过粗心了,具体如下:

  
  

如果你是这样的测试与旋度,然后使用——data-urlencode(而非- d)或设置一个明确的内容类型:文本/纯确保旋度编码数据正确当有特殊字符(“+”尤为棘手)。

     

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

        $ curl localhost: 7001/加密- h“内容类型:文本/普通”——data-urlencode“eF34 + 5江户=?   335年e618a02a0ff3dc1377321885f484fb2c19a499423ee7776755b875997b033      curl localhost: 7001美元/解密- h“内容类型:文本/普通”——data-urlencode“335 e618a02a0ff3dc1377321885f484fb2c19a499423ee7776755b875997b033”   eF34 + 5江户=      

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

        私有加密字符串(字符串值){   字符串url=" http://localhost: 7001/加密”;   请求请求=new Request.Builder ()   .url (url)   . post (RequestBody.create (MediaType.parse (" text/plain”), value.getBytes ()))   .build ();      打电话叫=okHttpClient.newCall(请求);   响应响应=call.execute ();   ResponseBody ResponseBody=response.body ();   返回responseBody.string ();   }      私人解密字符串(字符串值){   字符串url=" http://localhost: 7001/解密”;   请求请求=new Request.Builder ()   .url (url)   . post (RequestBody.create (MediaType.parse (" text/plain”), value.getBytes ()))   .build ();      打电话叫=okHttpClient.newCall(请求);   响应响应=call.execute ();   ResponseBody ResponseBody=response.body ();   返回responseBody.string ();   }      

  

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

春云配置对特殊字符加密处理的方法详解