热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

.Net下的加密解密大全(5):玩转对称加密

上篇博文介绍了怎么玩转Hash算法,不过那篇文章没有交代清楚。这篇博文我将力争将那些没交代清楚的东东都说明白了。当然本文的主题是玩转对称加密。.NET下的对称加密技术主要有这

    上篇博文介绍了怎么玩转Hash算法,不过那篇文章没有交代清楚。这篇博文我将力争将那些没交代清楚的东东都说明白了。当然本文的主题是玩转对称加密。

    .NET下的对称加密技术主要有这么几种:DES,AES,Rijndael,TripleDES(3DES)。现在就来玩转它们吧!与上篇博文一样,首先创建一个接口:“IEncryptAndDecrypt”,然后为DES,AES,Rijnael,TripleDES(3DES)建立对应的类并实现接口“IEncryptAndDecrypt”。它们的结果如下图:


    这样我们在后期的编程中只需要简单的调用接口IEncryptAndDecrypt中的方法“Encrypt”和“Decrypt”就可以对数据进行加密解密啦。当然要实现这样的愿望我们还得继续努力,当前我的目标就是为它们找一个合格的lead,这样我们如果要找DES干活就可以直接对lead说,而不用满世界的去找咱们的DES。来瞧瞧咱们的Lead吧:


咱们来瞧瞧这个Lead的能耐吧,看看它是否能胜任它的工作:

            EncryptAndDecryptInvoker leader;// = new EncryptAndDecryptInvoker(null, null);
            
            
            //执行环境
            CryptogramSetting setting = new CryptogramSetting() { };
            string data="快去干活";
            byte[] bData;//加密处理前
            byte[] aData;//机密处理后
            byte[] tmp;
            Encoding encoding=System.Text.Encoding.UTF8;



            //叫DES干活
            IEncrytAndDecrypt myDES = new DES();
            setting.IV = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 };
            setting.Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 };
            setting.CryptogramType = CryptogramType.SymmetryEncryptAndDecrypt;
            //给lead发送要求
            leader = new EncryptAndDecryptInvoker(myDES, setting);
           
            Console.WriteLine("DES:");
            tmp=leader.Encrypt(encoding.GetBytes(data));
            Console.WriteLine("加密:"+Convert.ToBase64String(tmp));
            tmp = leader.Decrypt(tmp);
            Console.WriteLine("解密:" + encoding.GetString(tmp));






            //叫AES干活
            IEncrytAndDecrypt myAES = new AES();
            setting.IV = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8,9,10,11,12,13,14,15,16 };
            setting.Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 ,9,10,11,12,13,14,15,16};
            setting.CryptogramType = CryptogramType.SymmetryEncryptAndDecrypt;
            //给lead发送要求
            leader = new EncryptAndDecryptInvoker(myAES, setting);

            Console.WriteLine("AES:");
            tmp = leader.Encrypt(encoding.GetBytes(data));
            Console.WriteLine("加密:" + Convert.ToBase64String(tmp));
            tmp = leader.Decrypt(tmp);
            Console.WriteLine("解密:" + encoding.GetString(tmp));
            
            
            
            
            
            
            
            
            //叫Rijndael干活
            IEncrytAndDecrypt myRijndael = new Rijndael();
            setting.IV = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 };
            setting.Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 };
            setting.CryptogramType = CryptogramType.SymmetryEncryptAndDecrypt;
            //给lead发送要求
            leader = new EncryptAndDecryptInvoker(myRijndael, setting);

            Console.WriteLine("Rijndael:");
            tmp = leader.Encrypt(encoding.GetBytes(data));
            Console.WriteLine("加密:" + Convert.ToBase64String(tmp));
            tmp = leader.Decrypt(tmp);
            Console.WriteLine("解密:" + encoding.GetString(tmp));


            //叫3DES干活
            IEncrytAndDecrypt my3DES = new TripleDES();
            setting.IV = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 };
            setting.Key = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16 };
            setting.CryptogramType = CryptogramType.SymmetryEncryptAndDecrypt;
            //给lead发送要求
            leader = new EncryptAndDecryptInvoker(my3DES, setting);

            Console.WriteLine("3DES:");
            tmp = leader.Encrypt(encoding.GetBytes(data));
            Console.WriteLine("加密:" + Convert.ToBase64String(tmp));
            tmp = leader.Decrypt(tmp);
            Console.WriteLine("解密:" + encoding.GetString(tmp));


            Console.ReadKey();

执行结果:

   

    看来我们的lead还是很给力的嘛,完全胜任了它的操作。

    


推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • GreenDAO快速入门
    前言之前在自己做项目的时候,用到了GreenDAO数据库,其实对于数据库辅助工具库从OrmLite,到litePal再到GreenDAO,总是在不停的切换,但是没有真正去了解他们的 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • 集成电路企业在进行跨隔离网数据交换时面临着安全性问题,传统的数据交换方式存在安全性堪忧、效率低下等问题。本文以《Ftrans跨网文件安全交换系统》为例,介绍了如何通过丰富的审批流程来满足企业的合规要求,保障数据交换的安全性。 ... [详细]
  • 如何提高PHP编程技能及推荐高级教程
    本文介绍了如何提高PHP编程技能的方法,推荐了一些高级教程。学习任何一种编程语言都需要长期的坚持和不懈的努力,本文提醒读者要有足够的耐心和时间投入。通过实践操作学习,可以更好地理解和掌握PHP语言的特异性,特别是单引号和双引号的用法。同时,本文也指出了只走马观花看整体而不深入学习的学习方式无法真正掌握这门语言,建议读者要从整体来考虑局部,培养大局观。最后,本文提醒读者完成一个像模像样的网站需要付出更多的努力和实践。 ... [详细]
author-avatar
手机用户2502919063
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有