XOR 是一个神奇的运算符, 观察它的真值表, 很容易得到以下结论:

假设现有 a , b 变量, 则

a ^ 0 == a

a ^ 0xff == ~a (取反加1等于作为补码的a的真值的相反数的补码, 比如0xff 取反加1 为 -1 的相反数 1 的补码 0x1, 0x0 取反加1 等于 0 的相反数 0 的补码, XOR 和相反数挂钩了!)

a ^ a == 0

XOR 满足交换律和结合律

a ^ b == b ^ a

a ^ b ^ a == b ^ (a ^ a) == b ^ 0 == b

这样一来, 可以使用一个中间变量 b , 使得 a ^ b 的值可以复原为 a , 这不正符合动态加密的需求吗?

说这些很无聊, 观察以下程序:

请问输出是什么? 抱歉, 我选择死亡!

问尼玛啊, 直接 Run 后观察不就好了?

如果你的程序有这种类似的提示, 那么很抱歉, 你将带给黑客极其重要的线索, 他只需简单地一调试, 关键代码就被定位到啦!

比如使用x64dbg定位字符串

剩下的先不说了, 我们写一个加密的程序吧?

这样一来, 可以在代码中使用混淆的数据了, 注意把解密函数和密钥隐藏起来哦.

/**
*加密神器
*对 long 和字符串进行 XOR 加密
*/ #include <stdio.h>
#include <stdlib.h>
#include <locale.h>
#include <tchar.h>
#include <string.h> unsigned int key; // 打印Usage
void printUsage(); // initializing
void init(); // encry
int encry(void *source, unsigned char key, unsigned short length); // get the hex type string
char *catX(const char *source, unsigned short length); // decode
char *decode(const char *source, unsigned char key);
void *ndecode(const void *source, unsigned char key, unsigned short length); ///////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////
int
main(int argc, const char **argv) {
init();
if (argc != 4) {
$Return:
printUsage();
return 0;
} if (sscanf(argv[3], "%x", &key) != 1) {
wprintf(L"key是一个 8 bit 十六进制数, 请检查!\n");
return 1;
} if (strcmp(argv[1], "-s") == 0) {
// eg: encry -s "支付失败!" 33
// 用户选择的是字符串加密
int length = strlen(argv[2]); wprintf(L"加密字符串 \"%S\" , 共 %d 个字节.\n", argv[2], length); char *str = (char *) malloc(length + 1);
if (str == NULL)
return 2;
if (strncpy(str, argv[2], length+1) == NULL){
return 1;
} if (encry(str, key, length) != 0)
return 1; wprintf(L"加密后显示为(key-0x%X):\n"
L"\"%S\"", key, (const char *)str);
puts(""); wprintf(L"加密前后的 ASCII 字串形式:\n"
"\"%S\"\n"
"\"%S\"\n", catX(argv[2], length), catX(str, length)); char *deco = decode(str, key);
wprintf(L"尝试解码:\n"
"\"%S\"", deco); free(str);
free(deco); } else if (strcmp(argv[1], "-n") == 0) {
// 用户选择的是 long 加密
long n = 0;
if (sscanf(argv[2], "%ld", &n) != 1) {
wprintf(L"请检查输入!\n");
return 1;
} wprintf(L"加密整数 %ld :\n", n);
encry(&n, key, sizeof(n));
printf("0x%lX\n", n);
wprintf(L"尝试解密:\n%ld\n", *(long *)ndecode(&n, key, sizeof(n))); } else {
goto $Return;
} return 0;
} void
init() {
// 本地化相关
setlocale(LC_CTYPE, "");
} void
printUsage() {
printf("%S", L"Usage:\n"
"\t encry -s <要加密的字符串> <key>\n"
"\t encry -n <要加密的整数> <key>\n");
} int
encry(void *source, unsigned char key, unsigned short length) {
if (source == NULL) {
printf("NULL Pointer Exception\n");
return -1;
}
int i = 0;
for (; i < length; i ++ ) {
((unsigned char *) source)[i] ^= key;
} return 0;
} char *
catX(const char *source, unsigned short length) {
if (source == NULL) {
return NULL;
}
int n = 4 * length, i = 0;
char *str = (char *) malloc(n + 1);
*str = '\0'; for (; i < length; i ++ ) {
unsigned char byte = source[i];
char tmp[5] = { 0 };
tmp[0] = '\\';
tmp[1] = 'x';
sprintf(&tmp[2], "%x", byte);
strcat(str, tmp);
} return str;
} char *
decode(const char *source, unsigned char key) {
if (source == NULL) {
printf("NULL Pointer Exception\n");
return NULL;
} int length = strlen(source);
char *str = (char *) malloc(length + 1);
strncpy(str, source, length + 1); while (*str != '\0') {
*str++ ^= key;
} return str - length;
} void *
ndecode(const void *source, unsigned char key, unsigned short length) {
if (source == NULL)
return NULL;
void *data = malloc(length); memcpy(data, source, length); int i = 0; for (; i < length; i ++ ) {
((char *) data)[i] ^= key;
} return data;
}
///////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////

  

XOR 加密的更多相关文章

  1. XOR 加密简介

    本文介绍一种简单高效.非常安全的加密方法:XOR 加密. 一. XOR 运算 逻辑运算之中,除了 AND 和 OR,还有一种 XOR 运算,中文称为"异或运算". 它的定义是:两个 ...

  2. 使用Z3破解简单的XOR加密

    使用Z3破解简单的XOR加密 翻译:无名侠 原文地址: https://yurichev.com/blog/XOR_Z3/ 如果我们有一段用简单XOR加密过的文本,怎么寻找密钥呢?密钥的长度可能很长, ...

  3. xor加密的python实现

    #md5加密 import hashlib hash_md5 = hashlib.md5() x=input("Please input your text:") print( & ...

  4. c语言实现xor加密

    异或运算:^ 定义:它的定义是:两个值相同时,返回false,否则返回true.也就是说,XOR可以用来判断两个值是否不同. 特点:如果对一个值连续做两次 XOR,会返回这个值本身. ^ // 第一次 ...

  5. XOR加密作业

    思路 -1.对需要加密的内容进行MD5加密 -2.随机生产32位的十六进制密钥 -3.对密钥和MD5加密内容进行异或运算. 主要问题: -1.如何实现MD5加密 -2.如何随机生成32位16进制密钥 ...

  6. XOR+base64加密

    1.xor运算 1^0=1 0^0=0 1^1=0 23^32=55 55^32=23 23对32进行异或两次运算结果为23 2.XOR加密 设key=[]byte{1,2,3,4,5,6},src= ...

  7. 详解XOR(异或)运算加密

    逻辑运算之中,除了 AND 和 OR,还有一种 XOR 运算,中文称为"异或运算".它的定义是:两个值相同时,返回false,否则返回true.也就是说,XOR可以用来判断两个值是 ...

  8. php源码安全加密之PHP混淆算法.

    php源码安全加密的前世今生,本想发在教程区中.不知道怎么发,就写在这里面吧.PHP加密,解密是一直的话题,本人菜鸟,今天就简单向大家介绍一下并说说其中原理.提供一些加密的混淆算法.一\PHP的加密总 ...

  9. Flash 加密和破解

    关于Flash(swf),我们需要明确一点: ***Flash字节码的意义都是公开的 所以如果cracker真的有足够的耐心他最终还是可以破解掉你的Flash.我们能做的只是尽量提高Flash被破解的 ...

随机推荐

  1. Redhat上为java Maven项目构建基于Jenkins + Github的持续集成环境

    在Redhat enterprise 6.5 的服务器上,为在gutub 上的 java mvaen项目构建一个持续集成环境,用到了Jenkins.因公司的服务器在内网,访问外网时要通过代理,所以为m ...

  2. [2017-7-27]Android Learning Day5

    总结篇! 吭哧吭哧了三天,最近不断研究<第一行代码:第二版>170多页的那个新闻实践项目,虽然也没有用到数据库和一些Web爬虫的知识,新闻数据都是随机生成的字符串...... 但还是很开心 ...

  3. 【原创】hdu1698 Just a Hook(线段树→区间更新,区间查询)

    学习线段树第二天,这道题属于第二简单的线段树,第一简单是单点更新,这个属于区间更新. 区间更新就是lazy思想,我来按照自己浅薄的理解谈谈lazy思想: 就是在数据结构中,树形结构可以线性存储(线性表 ...

  4. LVS负载均衡集群(DR)

    -----构建DR模式的LVS群集----- --client---------------------LVS------------------------WEB1----------------- ...

  5. 【Linux】linux中文本操作利器grep,awk,sed

    grep命令 grep(global search regular expression)是一种强大的文本搜索工具,它可以使用正则表达式搜索文本,并把匹配的行打印出来.平时搜索文本中内容的时候是非常方 ...

  6. 天梯赛 L2-001 紧急救援

    L2-001 紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市的救援队数量和每一条连接两个城市的快速道 ...

  7. 微信小程序支付(PHP后端)

    1.申请开通小程序支付,我们正式开通的微信支付是在微信公众平台上,我们需要绑定之前的微信商户平台即可,这一点不过多强调 2.小程序支付开发步骤 (1).统一下单 大家看到微信的统一下单接口密密麻麻的一 ...

  8. QML学习笔记(四)-TabView-竖直方向

    源码:https://github.com/sueRimn/QML-ExampleDemos 作者: 狐狸家的鱼 Github: 八至 版权声明:如需转载请获取授权和联系作者 想实现垂直竖直方向的Ta ...

  9. Django 跨域请求

    跨域:通过js或python在不同的域之间进行数据传输或通信,比如用ajax向一个不同的域请求数据,或者通过js获取页面中不同域的框架中(Django)的数据.只要协议.域名.端口有任何一个不同,都被 ...

  10. django中实现组合搜索

    一.简介 # 组合搜索# 技术方向:自动化,测试,运维,前端# 分类:Python Linux JavaScript OpenStack Node.js GO# 级别:初级 中级 高级 骨灰级 有4张 ...