欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android數(shù)據(jù)加密之異或加密算法的實(shí)現(xiàn)方法

 更新時(shí)間:2016年10月11日 09:35:22   投稿:jingxian  
下面小編就為大家?guī)硪黄狝ndroid數(shù)據(jù)加密之異或加密算法的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

這幾天被公司臨時(shí)拉到去做Android IM即時(shí)通信協(xié)議實(shí)現(xiàn),大致看了下他們定的協(xié)議,由于之前沒有參與,據(jù)說因服務(wù)器性能限制,只達(dá)成非明文傳遞,具體原因我不太清楚,不過這里用的加密方式是采用異或加密。這種加密方式在之前做Android加密記事本的時(shí)候采用過這種加密方式。今天已經(jīng)把客戶端心跳維持、數(shù)據(jù)包解析對(duì)接完了,總結(jié)一下這種加密方式。

什么是異或加密?

異或運(yùn)算中,如果某個(gè)字符(或數(shù)值)x 與 一個(gè)數(shù)值m 進(jìn)行異或運(yùn)算得到y(tǒng),則再用y 與 m 進(jìn)行異或運(yùn)算就可以還原為 x ,因此應(yīng)用這個(gè)原理可以實(shí)現(xiàn)數(shù)據(jù)的加密解密功能。

異或運(yùn)算使用場景?

兩個(gè)變量的互換(不借助第三個(gè)變量)

數(shù)據(jù)的簡單加密解密

異或加密解密實(shí)現(xiàn)?

1.固定key的方式

public byte[] encrypt(byte[] bytes) {
    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的方式

加密實(shí)現(xiàn)

public byte[] encrypt(byte[] bytes) {
    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;
  }

解密實(shí)現(xiàn)

public byte[] decrypt(byte[] bytes) {
    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));//解密

總結(jié):

位運(yùn)算可以實(shí)現(xiàn)很多高級(jí),高效的運(yùn)算。比如說加密,乘法中的n次方就是右移n位,速度還快。IM二進(jìn)制數(shù)據(jù)包采用異或算法第一能夠?qū)崿F(xiàn)加密,第二采用異或加密算法不會(huì)改變二進(jìn)制數(shù)據(jù)的長度這對(duì)二進(jìn)制數(shù)據(jù)包封包起到不小的好處。故作此總結(jié)。

以上就是小編為大家?guī)淼腁ndroid數(shù)據(jù)加密之異或加密算法的實(shí)現(xiàn)方法全部內(nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

最新評(píng)論