简介.Net框架下的各种加密解密算法

该文章将会不断的收入.net下的加密算法,这些算法将会采用策略模式来统一管理。

using System;
using System.Collections.Generic;
using System.Text;  

namespace EncryptAndDecrypt
{
   public class EncryptAndDecrytHandler
    {
        IEncrytAndDecrypt _EncryptAndDecrypt;
        public EncryptAndDecrytHandler(IEncrytAndDecrypt iencrytanddecrypt)
        {
            _EncryptAndDecrypt = iencrytanddecrypt;
        }
        public string Encrypt(string data)
        {
            return _EncryptAndDecrypt.Encrypt(data);
        }
        public string Decrypt(string data)
        {
            return _EncryptAndDecrypt.Decrypt(data);
        }
    }
}

加密解密的调用者

using System;
using System.Collections.Generic;
using System.Text;  

namespace EncryptAndDecrypt
{
    public interface IEncrytAndDecrypt
    {
       string Encrypt(string data);
       string Decrypt(string data);
    }
}

策略接口

using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Cryptography;
using System.IO;  

namespace EncryptAndDecrypt
{
    public class DESCrypt:IEncrytAndDecrypt
    {
        private byte[] rgbKey = new byte[] { 1, 9, 8, 7, 0, 1, 0, 3 };
        private byte[] rgbIv = new byte[] { 1, 9, 8, 7, 0, 1, 0, 3 };
        #region IEncrytAndDecrypt 成员  

        public string Encrypt(string data)
        {
            MemoryStream mstream = new MemoryStream();
            DESCryptoServiceProvider deskey = new DESCryptoServiceProvider();
            CryptoStream cstream = new CryptoStream(mstream, deskey.CreateEncryptor(rgbKey,rgbIv), CryptoStreamMode.Write);
            StreamWriter sw = new StreamWriter(cstream);
            sw.WriteLine(data);
            sw.Close();
            cstream.Close();
            byte[] bytes = mstream.ToArray();
            mstream.Close();
            return Convert.ToBase64String(bytes);
        }  

        public string Decrypt(string data)
        {
            string tmp;
            MemoryStream mstream = new MemoryStream(Convert.FromBase64String(data));
            DESCryptoServiceProvider deskey = new DESCryptoServiceProvider();
            CryptoStream cstream = new CryptoStream(mstream, deskey.CreateDecryptor(rgbKey, rgbIv), CryptoStreamMode.Read);
            StreamReader sr = new StreamReader(cstream);
            tmp = sr.ReadLine();
            sr.Close();
            cstream.Close();
            mstream.Close();
            return tmp;
        }  

        #endregion
    }
}

DES加密算法

using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Cryptography;
using System.IO;  

namespace EncryptAndDecrypt
{
   public class TripleDesCrypt:IEncrytAndDecrypt
    {
       private byte[] rgbKey;
       private byte[] rgbIv;
       public TripleDesCrypt()
       {
        rgbKey = new byte[130];
         rgbIv = new byte[130];
         for (int i = 0; i < 130; i++)
         {
             rgbKey[i] = rgbIv[i] = (byte)(new Random().Next(1, 255));
         }  

       }  

       #region IEncrytAndDecrypt 成员  

       public string Encrypt(string data)
        {
            TripleDESCryptoServiceProvider tripleDes=new TripleDESCryptoServiceProvider();  

            MemoryStream mstream = new MemoryStream();
            CryptoStream cstream = new CryptoStream(mstream, tripleDes.CreateEncryptor(rgbKey, rgbIv), CryptoStreamMode.Write);
            StreamWriter sw = new StreamWriter(cstream);
            sw.WriteLine(data);
            cstream.Close();
            byte[] result = mstream.ToArray();
            mstream.Close();
            return Convert.ToBase64String(result);  

        }  

        public string Decrypt(string data)
        {
            TripleDESCryptoServiceProvider tripleDes = new TripleDESCryptoServiceProvider();
            MemoryStream mstream = new MemoryStream(Convert.FromBase64String(data));
            CryptoStream cstream = new CryptoStream(mstream, tripleDes.CreateDecryptor(rgbKey, rgbIv), CryptoStreamMode.Read);
            StreamReader sr = new StreamReader(cstream);
            string result = sr.ReadLine();
            sr.Close();
            cstream.Close();
            mstream.Close();
            return result;
        }  

        #endregion
    }
}

TripleDES加密算法

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索string
, new
, using
, system
, public
, string算法
, MemoryStream
TripleDES
c 加密解密算法、java加密解密算法、java aes加密解密算法、加密解密算法、字符串加密解密算法,以便于您获取更多的相关知识。

时间: 2024-08-03 08:44:29

简介.Net框架下的各种加密解密算法的相关文章

详解.Net下的加密解密算法(6) 玩转非对称加密

本博文来聊聊怎么玩转非对称加密吧,这里主要介绍.NET算法下的3种非对称加密算法:DSA,RSA,ECDsa.上两篇博文分 别为Hash家族和非对称加密家族找到了lead,现在我们就为非对称加密技术找个合适的lead吧. 首先创建一个接口 :"IEncryptAndDecrypt",然后为上面的3中算法分别创建3个实现类并让这些类实现接口"IEncryptAndDecrypt".它们 的情况如下图: 这下我们把这些哥们都召集起来了,现在我们就给他们找一个lead:&

详解.NET下的加密解密算法(3) 非对称加密

本博文列出了.NET下常用的非对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助. RSA static string EnRSA(string data,string publickey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); byte[] cipherbytes; rsa.FromXmlString(publickey); cipherbytes = rsa.Encrypt(Encoding

详解.NET下的加密解密算法(2) 对称加密

本博文列出了.NET下常用的对称加密算法,并将它们制作成小DEMO,希望能对大家有所帮助. 公共代码 static byte[] CreateKey(int num) { byte[] result = new byte[num]; Random rand = new Random(); for (int i = 0; i < num; i++) { result[i] = (Byte)rand.Next(1, 256); } return result; } DES /// <summary

详解.NET下的加密解密算法(1) 哈希加密

.NET有丰富的加密解密API库供我们使用,本博文总结了.NET下的Hash散列算法,并制作成简单的DEMO,希望能对大家 有所帮助. MD5 using System; using System.Collections.Generic; using System.Text; using System.Security.Cryptography; namespace EncryptAndDecrypt { public class MD5 { public byte[] Hash(byte[]

java实现Base64加密解密算法_java

Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递较长的标识信息.例如,在Java Persistence系统Hibernate中,就采用了Base64来将一个较长的唯一标识符(一般为128-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数.在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式.

关于IEC62055-41标准协议中的加密解密算法的问题

问题描述 关于IEC62055-41标准协议中的加密解密算法的问题 大神们,菜鸟我看了IEC62055-41的中文版后,尝试着进行解密算法的编程,主要是其中的STA解密.我是在VS2010的环境下编写的,但就是跟文本的例子程序的结果对不上,折腾了一个多星期也没弄出来.求大神们解惑啊!!!!这是算法的图 解决方案 http://wenku.baidu.com/link?url=ZZftK7AWYYt4d8RhTnfmi9Lolpqx6rKc1q5h3tatYqMGLNFWSLjy8fVV2ckhr

PHP实现加密解密算法

PHP实现加密解密的算法,如下代码: <?php    class Mcrypt    {        /**        * 解密        *         * @param string $encryptedText 已加密字符串        * @param string $key  密钥        * @return string        */        public static function _decrypt($encryptedText,$key =

C#加密解密算法

加密|解密|算法 /*************************字符串加密算法***********************/public string EncryptString(string str)  {   char[] Base64Code=new char[]{'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','A','B

一组PHP可逆加密解密算法实例代码

 这篇文章主要介绍了一组PHP可逆加密解密算法实例代码,有需要的朋友可以参考一下 对于大部分密码加密,我们可以采用md5.sha1等方法.可以有效防止数据泄露,但是这些方法仅适用于无需还原的数据加密.   对于需要还原的信息,则需要采用可逆的加密解密算法.   下面一组PHP函数是实现此加密解密的方法:   加密算法如下: 代码如下: function encrypt($data, $key) {  $key = md5($key);     $x  = 0;     $len = strlen