CBrother异或加密与C++异或加密函数
CBrother脚本异或加密与C++异或加密函数
异或对于数据加密来说是最简单的方式,在一般的安全性要求不是非常高的地方,异或加密是最好的选择。
C++异或加密代码
- int g_PWD = 0xffee00aa; //密码
- void XORBuf(char *data,int len)
- {
- int *buf = (int *)data;
- int num = len >> ;//够4个字节的按整形异或
- for (int i = ; i < num ; i++)
- {
- buf[i] ^= g_PWD;
- }
- //不够4个字节的按位异或
- int tailnum = len & 0x3;
- if (tailnum > )
- {
- char *Byte = (char*)(buf + num);
- char *key = (char*)&g_PWD;
- for (int k = ; k < tailnum ; k++)
- {
- Byte[k] ^= key[k];
- }
- }
- }
CBrother异或加密代码
- var g_PWD = 0xffee00aa; //全局密钥
- function XORCode(byteArray,len)
- {
- var num = len >> 2;
- var ilen = num * 4;
- for (var i = 0 ; i < ilen ; i += 4) //够4个字节的
- {
- var b = byteArray.getByte(i) ^ (g_PWD & 255);
- var b1 = byteArray.getByte(i + 1) ^ (g_PWD >> 8 & 255);
- var b2 = byteArray.getByte(i + 2) ^ (g_PWD >> 16 & 255);
- var b3 = byteArray.getByte(i + 3) ^ (g_PWD >> 24 & 255);
- byteArray.setByte(i,b);
- byteArray.setByte(i + 1,b1);
- byteArray.setByte(i + 2,b2);
- byteArray.setByte(i + 3,b3);
- }
- //下面处理不够四个字节的
- var dlen = len - ilen;
- if(dlen >= 1)
- {
- var b = byteArray.getByte(i) ^ (g_PWD & 255);
- print b;
- byteArray.setByte(i++,b);
- }
- if(dlen >= 2)
- {
- var b = byteArray.getByte(i) ^ (g_PWD >> 8 & 255);
- print b;
- byteArray.setByte(i++,b);
- }
- if(dlen >= 3)
- {
- var b = byteArray.getByte(i) ^ (g_PWD >> 16 & 255);
- byteArray.setByte(i++,b);
- }
- }
对比一下还是很容易理解的
CBrother异或加密与C++异或加密函数的更多相关文章
- 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地
. 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地 本文来自异数OS社区 github: https://github.com/yds086/Here ...
- Android数据加密概述及多种加密方式 聊天记录及账户加密 提供高质量的数据保护
Android数据加密概述及多种加密方式 聊天记录及账户加密 提供高质量的数据保护 数据加密又称password学,它是一门历史悠久的技术,指通过加密算法和加密密钥将明文转变为密文.而解密则是通过解密 ...
- IOS中把字符串加密/IOS中怎么样MD5加密/IOS中NSString分类的实现
看完过后,你会学到: 1学习IOS开发中的分类实现, 2以及类方法的书写, 3以及字符串的MD5加密/解密. ---------------------------wolfhous---------- ...
- 16位的MD5加密和32位MD5加密的区别
16位的MD5加密和32位MD5加密的区别 MD5加密后所得到的通常是32位的编码,而在不少地方会用到16位的编码它们有什么区别呢?16位加密就是从32位MD5散列中把中间16位提取出来!其实破解16 ...
- 加密解密知识 php非对称加密
function test1(){ $config = array( "digest_alg" => "sha1", "private_key_ ...
- java实现DES加密与解密,md5加密
很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.Messa ...
- DotNet加密方式解析--散列加密
没时间扯淡类,赶紧上车吧. 在现代社会中,信息安全对于每一个人都是至关重要的,例如我们的银行账户安全.支付宝和微信账户安全.以及邮箱等等,说到信息安全,那就必须得提到加密技术,至于加密的一些相关概念, ...
- DES加密深度优化——随机生成加密字符串
DES全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法.但该算法一旦密钥固定,加密的字符串也就随之固定,这不利于数据存储安全.而且用该方法加密后有一个 ...
- php中des加密解密 匹配C#des加密解密 对称加密
原文:php中des加密解密 匹配C#des加密解密 对称加密 网上找来的 php des加密解密 完全匹配上一篇C# 字符串加密解密函数 可以用于C#和php通信 对数据进行加密,其中$key 是 ...
随机推荐
- EJB系列 - EJB基础知识
本人博客文章网址:https://www.peretang.com/basic-knowledge-of-ejb/ 什么是EJB 可移植的, 可重用的, 可伸缩的业务应用程序的平台 为什么选择EJB ...
- 从MySQL向Greenplum集群中导入数据
我们要从MySQL当中导出数据到Greenplum当中,按照以下步骤就可以 1:将MySQL当中的表导出外部文件 以schema_name.table_name为例 select product_id ...
- vs2017 调试时出现 cannot connect to runtime process错误
用Visual Studio 2017 .net core进行开发时 ,调试运行项目时出现如下错误 解决方案,调试>选项,取消勾选,关闭对JavaScript的调试
- Oracle 补丁那些事儿(PS、PSU、CPU、SPU、BP、DBBP…)
当前ORACLE数据库提供两种方式的补丁一种是主动的Proactive Patches和另一种被动的Reactive Patches,其中Reactive Patches是指过去的ONE-OFF Pa ...
- android 常用adb 及linux 命令
一.ADB相关 adb shell:进入连接的USB调试模式设备shell命令行下 adb tcpip 5555:将USB连接的调试及的连接方式改为网络远程模式进行调试 这里端口为5555(adb 默 ...
- LocationCoder 地图经纬度解析
LocationCoder 地图经纬度解析 其实,在地图里面将地图解析成有意义的地址,或者把地址转换成有意义的经纬度都是很容易的事情,只是我将其封装了支持KVO,通知中心,block取结果,代理取结果 ...
- 使用CoreData [1]
使用CoreData [1] 本篇教程能教你从无开始接触CoreData,包括新建工程,创建出实体,增删改查样样都有,属于使用CoreData最初级教程. 1. 创建带有CoreData的工程项目 2 ...
- HelloAndroid
Hello Android 代码 button.setOnClickListener { val alertDialog = AlertDialog.Builder(this) alertDialog ...
- [EffectiveC++]item27:尽量少做转型动作
- ui-sref
angularjs中路由跳转可以在模板页面上使用ui-sref="a-state({param1: value})"; 如果想为当前state的导航按钮添加一个激活class,可以 ...