zoukankan      html  css  js  c++  java
  • Base64编码的 换行 转义

    用Base64编码的时候如果出现 之类的字符,java中转义。

    当字符串过长(一般超过76)时会自动在中间加一个换行符,字符串最后也会加一个换行符。导致和其他模块对接时结果不一致。


    解决方法:
    将 
    android.util.Base64.encodeToString(input, Base64.DEFAULT)
    换成

    android.util.Base64.encodeToString(input, Base64.NO_WRAP);


    叠加使用Base64.URL_SAFE | Base64.NO_WRAP  去除 和 替换+ 和 - 号 


    Android自身带有Base64加密与解密的包,可以方便地加密密码方便传输。

     String base64Token = Base64.encodeToString(token.trim().getBytes(), Base64.NO_WRAP);

     byte[] mmmm = Base64.decode(base64Token,Base64.DEFAULT);

    在用Base64加密做签权的时候用Base64.DEFAULT一直不能签权成功。最后用Base64.NO_WRAP成功了。

    看起来用法与Java所带的sun.misc的Base64Encoder这些用法差不多,但应该留意到了,在encode的时候,会有一个参数Flags(即上面代码中的Base64.DEFAULT)

    这个参数有什么用呢?根据Android SDK的描述,这种参数有5个:

      1. CRLF 这个参数看起来比较眼熟,它就是Win风格的换行符,意思就是使用CR LF这一对作为一行的结尾而不是Unix风格的LF

      2. DEFAULT 这个参数是默认,使用默认的方法来加密

      3. NO_PADDING 这个参数是略去加密字符串最后的”=”

      4. NO_WRAP 这个参数意思是略去所有的换行符(设置后CRLF就没用了)

      5. URL_SAFE 这个参数意思是加密时不使用对URL和文件名有特殊意义的字符来作为加密字符,具体就是以-和_取代+和/

  • 相关阅读:
    Spring Boot 的单元测试和集成测试
    Containers vs Serverless:你选择谁,何时选择?
    Java13新特性
    Java中创建对象的5种方法
    最好的重试是指数后退和抖动
    杂谈:面向微服务的体系结构评审中需要问的三个问题
    使用Quarkus在Openshift上构建微服务的快速指南
    Java EE—最轻量级的企业框架?
    AQS机制
    JVM-内存模型
  • 原文地址:https://www.cnblogs.com/yiludugufei/p/7505080.html
Copyright © 2011-2022 走看看