Android中Base64编码

最近集成第三方sdk时需要Basic Authentication认证,在用Base64编码做签权的时候用Base64.DEFAULT一直不能签权成功,最后用Base64.NO_WRAP成功了。
后来查了一下原因,原来使用Base64.DEFAULT当字符串过长(一般超过76)时会自动在中间加一个换行符,字符串最后也会加一个换行符,这样就导致和其他模块对接时结果不一致,于是签权失败。而Base64.NO_WRAP 这个参数意思是略去所有的换行符,因此签权成功。
因此Android端使用Base64加编码解码时应使用Base64.NO_WRAP。
其他几种编码解码方式的含义:

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

DEFAULT:这个参数是默认,使用默认的方法来编码

NO_PADDING:这个参数是略去编码字符串最后的“=”

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

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

编码解码代码如下:

public class Base64Utils {
	 // 编码  
    public static String getBase64(String str) {  
        String result = "";  
        if( str != null) {
        	 try {  
             	result = new String(Base64.encode(str.getBytes("utf-8"), Base64.NO_WRAP),"utf-8");
             } catch (UnsupportedEncodingException e) {  
                 e.printStackTrace();  
             }  
        }
        return result;  
    }  
  
    // 解码
    public static String getFromBase64(String str) {  
        String result = "";  
        if (str != null) {  
            try {
				result = new String(Base64.decode(str, Base64.NO_WRAP), "utf-8");
			} catch (UnsupportedEncodingException e) {
				e.printStackTrace();
			}  
        }  
        return result;  
    }  
}
  • 7
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值