加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C#自定义基于Base64的加密解密类

发布时间:2020-12-15 17:57:45 所属栏目:百科 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 using System;using System.Security.Cryptography; using System.Text;namespace DotNet.Utilities{ /// summary /// Encrypt 的摘要说明。 /// /sum

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

using System;
using System.Security.Cryptography; 
using System.Text;
namespace DotNet.Utilities
{
    /// <summary>
    /// Encrypt 的摘要说明。
    /// </summary>
    public class DEncrypt
    {
        /// <summary>
        /// 构造方法
        /// </summary>
        public DEncrypt() 
        { 
        }
 
        #region 使用 缺省密钥字符串 加密/解密string
 
        /// <summary>
        /// 使用缺省密钥字符串加密string
        /// </summary>
        /// <param name="original">明文</param>
        /// <returns>密文</returns>
        public static string Encrypt(string original)
        {
            return Encrypt(original,"sharejs.com");
        }
        /// <summary>
        /// 使用缺省密钥字符串解密string
        /// </summary>
        /// <param name="original">密文</param>
        /// <returns>明文</returns>
        public static string Decrypt(string original)
        {
            return Decrypt(original,"sharejs.com",System.Text.Encoding.Default);
        }
 
        #endregion
 
        #region 使用 给定密钥字符串 加密/解密string
        /// <summary>
        /// 使用给定密钥字符串加密string
        /// </summary>
        /// <param name="original">原始文字</param>
        /// <param name="key">密钥</param>
        /// <param name="encoding">字符编码方案</param>
        /// <returns>密文</returns>
        public static string Encrypt(string original,string key) 
        { 
            byte[] buff = System.Text.Encoding.Default.GetBytes(original); 
            byte[] kb = System.Text.Encoding.Default.GetBytes(key);
            return Convert.ToBase64String(Encrypt(buff,kb));     
        }
        /// <summary>
        /// 使用给定密钥字符串解密string
        /// </summary>
        /// <param name="original">密文</param>
        /// <param name="key">密钥</param>
        /// <returns>明文</returns>
        public static string Decrypt(string original,string key)
        {
            return Decrypt(original,key,System.Text.Encoding.Default);
        }
 
        /// <summary>
        /// 使用给定密钥字符串解密string,返回指定编码方式明文
        /// </summary>
        /// <param name="encrypted">密文</param>
        /// <param name="key">密钥</param>
        /// <param name="encoding">字符编码方案</param>
        /// <returns>明文</returns>
        public static string Decrypt(string encrypted,string key,Encoding encoding) 
        {      
            byte[] buff = Convert.FromBase64String(encrypted); 
            byte[] kb = System.Text.Encoding.Default.GetBytes(key);
            return encoding.GetString(Decrypt(buff,kb));     
        } 
        #endregion
 
        #region 使用 缺省密钥字符串 加密/解密/byte[]
        /// <summary>
        /// 使用缺省密钥字符串解密byte[]
        /// </summary>
        /// <param name="encrypted">密文</param>
        /// <param name="key">密钥</param>
        /// <returns>明文</returns>
        public static byte[] Decrypt(byte[] encrypted) 
        { 
            byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com");
            return Decrypt(encrypted,key);    
        }
        /// <summary>
        /// 使用缺省密钥字符串加密
        /// </summary>
        /// <param name="original">原始数据</param>
        /// <param name="key">密钥</param>
        /// <returns>密文</returns>
        public static byte[] Encrypt(byte[] original) 
        { 
            byte[] key = System.Text.Encoding.Default.GetBytes("sharejs.com");
            return Encrypt(original,key);    
        } 
        #endregion
 
        #region  使用 给定密钥 加密/解密/byte[]
 
        /// <summary>
        /// 生成MD5摘要
        /// </summary>
        /// <param name="original">数据源</param>
        /// <returns>摘要</returns>
        public static byte[] MakeMD5(byte[] original)
        {
            MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();  
            byte[] keyhash = hashmd5.ComputeHash(original);      
            hashmd5 = null; 
            return keyhash;
        }
 
 
        /// <summary>
        /// 使用给定密钥加密
        /// </summary>
        /// <param name="original">明文</param>
        /// <param name="key">密钥</param>
        /// <returns>密文</returns>
        public static byte[] Encrypt(byte[] original,byte[] key) 
        { 
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();      
            des.Key =  MakeMD5(key);
            des.Mode = CipherMode.ECB; 
      
            return des.CreateEncryptor().TransformFinalBlock(original,original.Length);    
        } 
 
        /// <summary>
        /// 使用给定密钥解密数据
        /// </summary>
        /// <param name="encrypted">密文</param>
        /// <param name="key">密钥</param>
        /// <returns>明文</returns>
        public static byte[] Decrypt(byte[] encrypted,byte[] key) 
        { 
            TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider(); 
            des.Key =  MakeMD5(key);   
            des.Mode = CipherMode.ECB; 
 
            return des.CreateDecryptor().TransformFinalBlock(encrypted,encrypted.Length);
        } 
   
        #endregion
 
         
 
         
    }
}

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读