简单异或加密处理

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u014476720/article/details/85046207

异或的理解: 将十进制转换成二进制进行异或,相同的为0 ,不相同的为1,可以看下图理解,异或之后得出的二进制再转十进制,之后的就是异或后的值

断点查看过程:

异或前:

异或后:

Java版代码:

  private static byte[] keyBytes = {1,5,3,4,5};

    public static String xor_go(String enc){
        byte[] b = enc.getBytes(Charset.forName("UTF-8"));
        for(int i=0;i<b.length;i++){
            b[i] = (byte) (b[i]^(keyBytes[i%keyBytes.length]));
        }
        return new String(b);
    }

使用:加密和解密都是同一个方法

C++版,jni里面用的,可以加密重要的字符串,为调试增加一点点难度吧

int key[] = {1, 5, 3, 4, 5};//加密字符
//异或加密
void xor_go(char *pstr, int *pkey) {
    int len = strlen(pstr);//获取长度
    for (int i = 0; i < len; i++) {
        *(pstr + i) = ((*(pstr + i)) ^ (pkey[i % 5]));
    }
}

用法:

/**
 * 执行加密解密的方法
 */
char *sub_go(char *s, int type) {
    char *p = s;
    if (type == 1) {
        xor_go(s, key);//加密
        // LOGE("加密后 %s", p);
    }
    xor_go(s, key);//解密
    //  LOGE("解密后 %s", p);
    return p;
}

s传入的是char s[] 数组类型

猜你喜欢

转载自blog.csdn.net/u014476720/article/details/85046207