asp.net TripleDES加密、解密算法_实用技巧

using System;   

using System.Collections.Generic;   

using System.Linq;   

using System.Text;   

using System.Security.Cryptography;   

using System.IO;   

namespace WindowsFormsApplication1   

{  

    #region TripleDES算法   

  

    public class ClassTripleDES   

    {   

        public ClassTripleDES()   

        {   

        }   

  

        //加密,使用密码产生加密算法的公钥,并使用TripleDES对密码进行加密。   

        public static string Encrypt(string pass)   

        {   

            try  

            {   

                byte[] bt = (new System.Text.UnicodeEncoding()).GetBytes(pass);   

                PasswordDeriveBytes pdb = new PasswordDeriveBytes(pass, null);   

                byte[] key = pdb.GetBytes(24);   

                byte[] iv = pdb.GetBytes(8);   

                MemoryStream ms = new MemoryStream();   

                TripleDESCryptoServiceProvider tdesc = new TripleDESCryptoServiceProvider();   

                CryptoStream cs = new CryptoStream(ms, tdesc.CreateEncryptor(key, iv), CryptoStreamMode.Write);   

                cs.Write(bt, 0, bt.Length);   

                cs.FlushFinalBlock();   

                return Convert.ToBase64String(ms.ToArray());   

            }   

            catch (Exception ex)   

            {   

                throw ex;   

            }   

        }   

  

        //解密,使用密码产生加密算法的公钥,并使用TripleDES对加密数据进行解密。   

        public static string Decrypt(string str, string pass)   

        {   

            try  

            {   

                byte[] bt = Convert.FromBase64String(str);   

                PasswordDeriveBytes pdb = new PasswordDeriveBytes(pass, null);   

                byte[] key = pdb.GetBytes(24);   

                byte[] iv = pdb.GetBytes(8);   

                MemoryStream ms = new MemoryStream();   

                TripleDESCryptoServiceProvider tdesc = new TripleDESCryptoServiceProvider();   

                CryptoStream cs = new CryptoStream(ms, tdesc.CreateDecryptor(key, iv), CryptoStreamMode.Write);   

                cs.Write(bt, 0, bt.Length);   

                cs.FlushFinalBlock();   

                return (new System.Text.UnicodeEncoding()).GetString(ms.ToArray());   

            }   

            catch (Exception ex)   

            {   

                throw ex;   

            }   

        }   

        //使用:   

        //string str = Encrypt("bbb");   

        //Console.WriteLine(Decrypt(str, "bbb"));   

  

        //加密,使用密码产生加密算法的公钥,并使用TripleDES对密码进行加密。   

        public static string EncryptWithKey(string pass, string p_key)   

        {   

            try  

            {   

                byte[] bt = (new System.Text.UnicodeEncoding()).GetBytes(pass);   

                PasswordDeriveBytes pdb = new PasswordDeriveBytes(p_key, null);   

                byte[] key = pdb.GetBytes(24);   

                byte[] iv = pdb.GetBytes(8);   

                MemoryStream ms = new MemoryStream();   

                TripleDESCryptoServiceProvider tdesc = new TripleDESCryptoServiceProvider();   

                CryptoStream cs = new CryptoStream(ms, tdesc.CreateEncryptor(key, iv), CryptoStreamMode.Write);   

                cs.Write(bt, 0, bt.Length);   

                cs.FlushFinalBlock();   

                return Convert.ToBase64String(ms.ToArray());   

            }   

            catch (Exception ex)   

            {   

                throw ex;   

            }   

        }   

  

        //解密,使用密码产生加密算法的公钥,并使用TripleDES对加密数据进行解密。   

        public static string DecryptWithKey(string str, string p_key)   

        {   

            try  

            {   

                byte[] bt = Convert.FromBase64String(str);   

                PasswordDeriveBytes pdb = new PasswordDeriveBytes(p_key, null);   

                byte[] key = pdb.GetBytes(24);   

                byte[] iv = pdb.GetBytes(8);   

                MemoryStream ms = new MemoryStream();   

                TripleDESCryptoServiceProvider tdesc = new TripleDESCryptoServiceProvider();   

                CryptoStream cs = new CryptoStream(ms, tdesc.CreateDecryptor(key, iv), CryptoStreamMode.Write);   

                cs.Write(bt, 0, bt.Length);   

                cs.FlushFinalBlock();   

                return (new System.Text.UnicodeEncoding()).GetString(ms.ToArray());   

            }   

            catch (Exception ex)   

            {   

                throw ex;   

            }   

        }   

  

    }  

 

    #endregion   

}  

时间: 2024-09-18 04:38:41

asp.net TripleDES加密、解密算法_实用技巧的相关文章

asp.net 字符串加密解密技术_实用技巧

复制代码 代码如下: using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using Syste

asp.net web.config加密解密方法_实用技巧

使用命令行工具aspnet_regiis.exe 你还能够使用aspnet_regiis.exe命令行工具来加密和解密Web.config文件配置部分,你可以在"%WINDOWSDIR%\Microsoft.Net\Framework\version"目录下找到这个工具.为了加密Web.config文件中的一个节,你可以在这个命令行工具中使用DPAPI机器密钥,如下所示: 加密一个特定网站的Web.config文件的通用形式: 复制代码 代码如下: aspnet_regiis.exe

asp.net EncryptHelper 加密帮助类_实用技巧

复制代码 代码如下: /************************************************** * 版权所有: Mr_Sheng * 文 件 名: EncryptHelper.cs * 文件描述: * 类型说明: EncryptHelper 加密帮助类 * 授权声明: * 本程序为自由软件: * 您可依据自由软件基金会所发表的GPL v3授权条款,对本程序再次发布和/或修改: * 本程序是基于使用目的而加以发布,然而不负任何担保责任: * 亦无对适售性或特定目的适用

Win 2000下ASP.NET开发环境的配置_实用技巧

Win 2000下ASP.NET的配置 Win 2000(包括Professional,Server和Advanced Server)在默认情况下是不支持ASP.NET的.必须对它进行一个环境的配置. 客户端 SQL Server .NET 数据提供程序 Microsoft 数据访问组件 (MDAC) 2.6 或更高版本 对系统管理信息的访问 Windows Management Instrumentation (WMI)(在 Windows 2000操作系统一起安装)COM+ 服务 Windo

php结合md5的加密解密算法实例_php技巧

本文实例讲述了php结合md5的加密解密算法.分享给大家供大家参考,具体如下: <?php /* * Created on 2016-9-30 * */ function encrypt($data, $key) { $key = md5($key); $x = 0; $len = strlen($data); $l = strlen($key); for ($i = 0; $i < $len; $i++) { if ($x == $l) { $x = 0; } $char .= $key{$

asp.net 对中文汉字的加密与解密代码_实用技巧

复制代码 代码如下: protected void Page_Load(object sender, EventArgs e) { //加密算法 string username = "我是陈建勇"; //MD5加密 - 得到32位加密数据,数据不好解密.过于复杂. username =FormsAuthentication.HashPasswordForStoringInConfigFile(username, "MD5"); //SHA1加密 - 得到40位加密数

在ASP.Net中实现RSA加密的方法_实用技巧

在我们实际运用中,加密是保证数据安全的重要手段.以前使用ASP时,对数据加密可以使用MD5和SHA1算法,这两种算法虽然快捷有效,但是无法对通过它们加密的密文进行反运算,即是解密.因此需要解密数据的场合,这两种方法就不太适合了.当然你也可以自己编写适用的加密和解密程序,不过这对编写者的数学水平有很高的要求,一般人是很难做到的. 现在,随着ASP.Net的推出,彻底改变了以前ASP下的编程模式.我们能够利用.Net Framework中的类提供的加密服务来保证数据安全.目前应用较为广泛的加密方法是

.NET中的DES对称加密详解_实用技巧

DES算法一般有两个关键点,第一个是加密模式,第二个是数据补位,加密模式的主要意义就是,加密算法是按块进行加密的,例如 DES ,是 64Bit 一个块的进行加密,就是每次加密 8 个字节,因此每次输入八个字节的明文输出八个字节密文,如果是 16 个字节,那么分成两个块依次进行加密,问题就出现在这里,如果明文是 1234567812345678,分块分别进行加密,那么加密的结果类似"C4132737962C519C C4132737962C519C",可以看出明文的规律,这就是 ECB

厉害的用Asp获取Dll加密新闻内容_应用技巧

以下是代码: 复制代码 代码如下: <%  on error resume next    Dim objXMLHTTP, xml    Set xml = Server.CreateObject("Microsoft.XMLHTTP")     xml.Open "GET", "http://chanye.finance.sina.com.cn/yj/2005-01-05/236914.shtml", False    xml.Send