位运算加密,解密问题

Eddie780 2016-09-03 08:24:21
几个位运算中,好像只有异或能实现加密并解密吧?比如0x1F ^ 7 结果值再^7能回到0x1F,其他的好像都不可逆。请问还有什么方法能把一个单字节变量加密解密呢?不能直接用+或-,会进到高位或减太多变负数,谢谢大家!
...全文
210 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
dustpg 2016-09-03
  • 打赏
  • 举报
回复
....负数又不是不能用, 负数再减回去不就行了.. 除了基本的位运算, 还有比如按位循环左/右移..这一般有直接的指令, 甚至还能打乱位顺序
paschen 版主 2016-09-03
  • 打赏
  • 举报
回复
那是因为异或加密具有可逆性,只要在一次异或就可解密,你只需要找一个同样具有可逆的算法即可,比如按位取反也可以
ztenv 版主 2016-09-03
  • 打赏
  • 举报
回复
非摘要的加密/解密一般都是可逆的,如:des、3des等等,
ForestDB 2016-09-03
  • 打赏
  • 举报
回复
随便举个例子,可以把高低字节swap; 又或者把相邻bit交换。

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧