欢迎来到代码驿站!

Android代码

当前位置:首页 > 移动开发 > Android代码

解析Android数据加密之异或加密算法

时间:2020-10-11 10:46:32|栏目:Android代码|点击:

前言:

这几天被公司临时拉到去做Android IM即时通信协议实现,大致看了下他们定的协议,由于之前没有参与,据说因服务器性能限制,只达成非明文传递,具体原因我不太清楚,不过这里用的加密方式是采用异或加密。这种加密方式在之前做Android加密记事本的时候采用过这种加密方式。今天已经把客户端心跳维持、数据包解析对接完了,总结一下这种加密方式。

其他几种加密方式:

什么是异或加密?

异或运算中,如果某个字符(或数值)x 与 一个数值m 进行异或运算得到y,则再用y 与 m 进行异或运算就可以还原为 x ,因此应用这个原理可以实现数据的加密解密功能。

异或运算使用场景?

  • 两个变量的互换(不借助第三个变量)
  • 数据的简单加密解密

异或加密解密实现?

1.固定key的方式

这种方式加密解密 算法一样

public byte[] encrypt(byte[] bytes) {
 if (bytes == null) {
  return null;
 }
 int len = bytes.length;
 int key = 0x12;
 for (int i = 0; i < len; i++) {
  bytes[i] ^= key;
 }
 return bytes;
 }

测试加密解密

 byte[] bytes = encrypt("whoislcj".getBytes());//加密
 String str1 = new String(encrypt(bytes));//解密

 2.不固定key的方式

加密实现

 public byte[] encrypt(byte[] bytes) {
 if (bytes == null) {
  return null;
 }
 int len = bytes.length;
 int key = 0x12;
 for (int i = 0; i < len; i++) {
  bytes[i] = (byte) (bytes[i] ^ key);
  key = bytes[i];
 }
 return bytes;
 }

 解密实现
 

public byte[] decrypt(byte[] bytes) {
 if (bytes == null) {
  return null;
 }
 int len = bytes.length;
 int key = 0x12;
 for (int i = len - 1; i > 0; i--) {
  bytes[i] = (byte) (bytes[i] ^ bytes[i - 1]);
 }
 bytes[0] = (byte) (bytes[0] ^ key);
 return bytes;
 }

 测试

 byte[] bytes = encrypt("whoislcj".getBytes());//加密
 String str1 = new String(decrypt(bytes));//解密

总结:

位运算可以实现很多高级,高效的运算。比如说加密,乘法中的n次方就是右移n位,速度还快。IM二进制数据包采用异或算法第一能够实现加密,第二采用异或加密算法不会改变二进制数据的长度这对二进制数据包封包起到不小的好处。故作此总结。

上一篇:Android studio实现刮刮乐的方法

栏    目:Android代码

下一篇:Android编程之计时器Chronometer简单示例

本文标题:解析Android数据加密之异或加密算法

本文地址:http://www.codeinn.net/misctech/9903.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有