Android数据加密之Base64编码算法的简单实现
前面学习总结了平时开发中遇见的各种数据加密方式,最终都会对加密后的二进制数据进行base64编码,起到一种二次加密的效果,其实呢base64从严格意义上来说的话不是一种加密算法,而是一种编码算法,为何要使用base64编码呢?它解决了什么问题?这也是本文探讨的东西?
什么base64算法?
base64是网络上最常见的用于传输8bit字节代码的编码方式之一,base64并不是安全领域的加密算法,其实base64只能算是一个编码算法,对数据内容进行编码来适合传输。标准base64编码解码无需额外信息即完全可逆,即使你自己自定义字符集设计一种类base64的编码方式用于数据加密,在多数场景下也较容易破解。base64编码本质上是一种将二进制数据转成文本数据的方案。对于非二进制数据,是先将其转换成二进制形式,然后每连续6比特(2的6次方=64)计算其十进制值,根据该值在a--z,a--z,0--9,+,/ 这64个字符中找到对应的字符,最终得到一个文本字符串。基本规则如下几点:
标准base64只有64个字符(英文大小写、数字和+、/)以及用作后缀等号;base64是把3个字节变成4个可打印字符,所以base64编码后的字符串一定能被4整除(不算用作后缀的等号);等号一定用作后缀,且数目一定是0个、1个或2个。这是因为如果原文长度不能被3整除,base64要在后面添加\0凑齐3n位。为了正确还原,添加了几个\0就加上几个等号。显然添加等号的数目只能是0、1或2;严格来说base64不能算是一种加密,只能说是编码转换。
下图为base64编码表
base64编码的用处?
在计算机中任何数据都是按ascii码存储的,而ascii码的128~255之间的值是不可见字符。而在网络上交换数据时,比如说从a地传到b地,往往要经过多个路由设备,由于不同的设备对字符的处理方式有一些不同,这样那些不可见字符就有可能被处理错误,这是不利于传输的。所以就先把数据先做一个base64编码,统统变成可见字符,这样出错的可能性就大降低了。
base64具体实现
1.)字符串进行base64编码
string encodedstring = base64.encodetostring("whoislcj".getbytes(), base64.default); log.e("base64", "base64---->" + encodedstring);
2.)字符串进行base64解码
string decodedstring =new string(base64.decode(encodedstring,base64.default)); log.e("base64", "base64---->" + decodedstring);
3.)对文件进行base64编码
file file = new file("/storage/emulated/0/pimsecure_debug.txt"); fileinputstream inputfile = null; try { inputfile = new fileinputstream(file); byte[] buffer = new byte[(int) file.length()]; inputfile.read(buffer); inputfile.close(); encodedstring = base64.encodetostring(buffer, base64.default); log.e("base64", "base64---->" + encodedstring); } catch (exception e) { e.printstacktrace(); }
4.)对文件进行base64解码
file desfile = new file("/storage/emulated/0/pimsecure_debug_1.txt"); fileoutputstream fos = null; try { byte[] decodebytes = base64.decode(encodedstring.getbytes(), base64.default); fos = new fileoutputstream(desfile); fos.write(decodebytes); fos.close(); } catch (exception e) { e.printstacktrace(); }
5.)针对base64.default参数说明
无论是编码还是解码都会有一个参数flags,android提供了以下几种
default 这个参数是默认,使用默认的方法来加密
no_padding 这个参数是略去加密字符串最后的”=”
no_wrap 这个参数意思是略去所有的换行符(设置后crlf就没用了)
crlf 这个参数看起来比较眼熟,它就是win风格的换行符,意思就是使用cr lf这一对作为一行的结尾而不是unix风格的lf
url_safe 这个参数意思是加密时不使用对url和文件名有特殊意义的字符来作为加密字符,具体就是以-和_取代+和/
总结:
base64编码看似简单,但是其在实际开发中使用相当广泛。目前项目中只是用到这么多,以后用到更复杂的情况的时候再做补充。
以上就是小编为大家带来的android数据加密之base64编码算法的简单实现全部内容了,希望大家多多支持~
推荐阅读
-
Android数据加密之Base64编码算法的简单实现
-
Android数据加密之Base64编码算法的简单实现
-
Android数据加密之异或加密算法的实现方法
-
Android数据加密之Rsa加密的简单实现
-
Android数据加密之Rsa加密的简单实现
-
Android数据加密之异或加密算法的实现方法
-
Android数据加密之——Base64编码算法
-
Unity 基础 之 实现简单的Android移动端本地数据读取与写入封装(简单加密写入,解密读取 json 数据)
-
android硬编码h264数据,并使用rtp推送数据流,实现一个简单的直播-MediaCodec(二)
-
android硬编码h264数据,并使用rtp推送数据流,实现一个简单的直播-MediaCodec