异或加密算法--简单快速的文本加密算法

思路:原理是用字节b对字节A异或两次结果还是A;

#include <iostream>

void encryp(char *pContents, std::string key);
void decryp(char *pContents, std::string key);

int main()
{
    //test
    std::string key = "123456";
    char contents[] = "Hello World!\n";
    encryp(contents, key);
    std::cout << "encryp:" << std::string(contents) << std::endl;
    decryp(contents, key);
    std::cout << "decryp:" << std::string(contents) << std::endl;
    //
    return 0;
}

//加密
void encryp(char *pContents, std::string key){
    char *pCur = pContents;
    int i = 0;
    int len = strlen(pContents);
    while(len--){
        *pCur ^= key.at(i);
        i = (i+1)%key.size();
        pCur++;
    }
}

//解密
void decryp(char *pContents, std::string key){
    char *pCur = pContents;
    int i = 0;
    int len = strlen(pContents);
    while(len--){
        *pCur ^= key.at(i);
        i = (i+1)%key.size();
        pCur++;
    }
}

好处:
只要保证key不泄露,暴力破解其实也不好破解(有懂的欢迎评论区讨论);
对于普通业务的文本资料混淆特别好用;
对于exe、图片、视频加密很好用,可以只解密其中的某一部分字节,这样资料就损坏了;
加密效率高;
实现简单;

问题:
对同一文本加密两次会无效,实际项目需要添加已加密的标识

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值