说明:
Android自身带有Base64加密与解密的包,可以方便地加密密码方便传输。
代码:
import android.util.Base64 String str = "Hello!"; //base64编码 String strBase64 = Base64.encodeToString(str.getBytes(), Base64.DEFAULT); //base64解码 String str2 = new String(Base64.decode(strBase64.getBytes(), Base64.DEFAULT));
默认类型:
如果在用Base64加密做签权的时候用Base64.DEFAULT一直不能签权成功。可以用Base64.NO_WRAP。
看起来用法与Java所带的sun.misc的Base64Encoder这些用法差不多,但应该留意到了,在encode的时候,会有一个参数Flags(即上面代码中的Base64.DEFAULT)
这个参数有什么用呢?根据Android SDK的描述,这种参数有5个:
CRLF 这个参数看起来比较眼熟,它就是Win风格的换行符,意思就是使用CRLF这一对作为一行的结尾而不是Unix风格的LF
DEFAULT 这个参数是默认,使用默认的方法来加密
NO_PADDING 这个参数是略去加密字符串最后的”=”
NO_WRAP 这个参数意思是略去所有的换行符(设置后CRLF就没用了)
URL_SAFE 这个参数意思是加密时不使用对URL和文件名有特殊意义的字符来作为加密字符,具体就是以-和_取代+和/