首页 > 代码库 > 使用异或运算符对整数进行加密

使用异或运算符对整数进行加密

一:什么是∧运算符:

二元 ^ 运算符是为整型和 bool 类型预定义的。对于整型,^ 将计算操作数的按位“异或”。对于 bool 操作数,^ 将计算操作数的逻辑“异或”;也就是说,当且仅当只有一个操作数为 true 时,结果才为 true。

二:在进行异或运算规则:

如两个二进制数的相应位都为1 或者二进制数的相应位都为0,则返回0;如果两个二进制数相应位一个为0,另一个为1则返回1;

三:异或运算的执行过程:

加密:将23进行异或运算加密,key为15

  1. 数值23转为二进制为: 10111  --注1
  2. 加密数值15为2进制为: 1111 
  3. 对两个数从右边按左比较,按异或运算规则比较为,得到结果为:11000  --注2
  4. 将11000转为10进制,得到加密结果为:24 --注3

解密:将加密结果:24进行异或运算解密,key=15

  1. 将24转为二进制:11000
  2. 将15转为二进制:  1111
  3. 对11000和1111进行异或运算得到结果为:10111
  4. 10111转为十进制:23

注释1:23转2进制算法流程

  1. 23/2=11   余1
  2. 11/2=5     余1
  3. 5/2=2       余1
  4. 2/2=1       余0
  5. 1/2除不够余1
  6. 把余数到着排列:10111

注释2:将10111和1111进行异或运算规则比较:

  1. 数字:10111
  2. 数字:  1111
  3. 结果:11000

注释3:11000转为10进制数:1*2^4+1*2^3+0*2^2+0*2^1+0*2^0=16+8+0+0+0=24

四:编写加密小工具:

技术分享

程序的主要代码如下:

        /// <summary>        ///加密        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void button1_Click(object sender, EventArgs e)        {            int num, key;            if (int.TryParse(this.textBox1.Text, out key) && int.TryParse(this.textBox2.Text, out num))            {                this.label4.Text = (num ^ key).ToString();            }            else            {                MessageBox.Show("请输入数值","出现错误");            }        }
        /// <summary>        /// 解密        /// </summary>        /// <param name="sender"></param>        /// <param name="e"></param>        private void button2_Click(object sender, EventArgs e)        {            int key, encrypt;            if (int.TryParse(this.textBox1.Text, out key) && int.TryParse(this.label4.Text,out  encrypt))            {                this.label5.Text = (key ^ encrypt).ToString();            }            else            {                MessageBox.Show("请输入数值", "出现错误");            }        }

 

使用异或运算符对整数进行加密