C#使用异或操作符进行加密/解密

本文介绍了如何使用C#的异或操作符进行加密和解密。加密过程通过异或运算生成不可读的密文,而解密则通过相同的操作还原原文。这种加密方式属于对称加密,即加密和解密使用同一密钥。同时,简要提到了非对称加密算法,其特点是公钥用于加密,私钥用于解密,只有拥有私钥才能解密信息。
摘要由CSDN通过智能技术生成

加密/解密技术:

通过一次异或运算,生成密文,密文没有可读性,与原文风马牛不相及,这就是加密;
密文再经过一次异或运算,就会还原成原文,这就是解密的过程;
加密和解密需要相同的密钥,如果密钥不对,是无法成功解密的。
上面的加密算法称为对称加密算法,加密和解密使用同一个密钥。

如果加密和解密的密钥不同,则称为非对称加密算法。在非对称算法中,加密的密钥称为公钥,解密的密钥称为私钥,只知道公钥是无法解密的,还必须知道私钥。

实例:

            string content = "GER";
            string key = "BIO";
            var content_char = System.Text.Encoding.Unicode.GetBytes(content);
            var key_char = System.Text.Encoding.Unicode.GetBytes(key);
            //加密
            byte[] content_after_char = new byte[content_char.Length];  //加密后的字符数组
            for (int i = 0; i < content_char.Length; i++)
            {
                content_after_char[i] = (byte)(content_char[i] ^ key_char[i]);
            }
            var content_after_string = System.Text.Encoding.Unicode.GetString(content_after_char);
 
            //解密
            byte[] content_before_char = new byte[content_char.Length];  //解密后的字符数组
            for (int i = 0; i < content_char.Length; i++)
            {
                content_before_char[i] = (byte)(content_after_char[i] ^ key_char[i]);
            }
            var content_before_string = System.Text.Encoding.Unicode.GetString(content_before_char);
            Console.WriteLine(string.Format("原文:{0}", content));
            Console.WriteLine(string.Format("加密后的内容:{0}", content_after_string));
            Console.WriteLine(string.Format("解密后的内容:{0}", content_before_string));

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值