程序开发中常用的加加密类!

本文详细介绍了SHA1和3DES两种加密算法的具体实现方式,包括SHA1的不可逆特性及其在密码验证中的应用,以及3DES算法的加密与解密过程。此外,还提供了代码示例来帮助理解。

 

/*
 * 功能:系统的SHA1加密 ,此类的功能与MD5一样,都是不可逆,经常用于口令密码的配对。
 */
using System;
using System.Collections.Generic;
using System.Text;
using System.Security.Cryptography;
using System.IO;
/// <summary>
/// 功能:系统的SHA1加密
/// </summary>
public class SHA1Helper
{
    // Methods
    public bool CompareHash(string source, string entStr)
    {
        if ((source == null) || (entStr == null))
        {
            return false;
        }
        return this.GetSha1String(source).Equals(entStr);
    }

    public string GetSha1String(string strSource)
    {
        SHA1 sha = new SHA1CryptoServiceProvider();
        return Convert.ToBase64String(sha.ComputeHash(Encoding.UTF8.GetBytes(strSource)));
    }
}


/// <summary>
/// 系统加密类
/// </summary>
public class MD5Encrypt
{
    /// <summary>
    /// MD5加密
    /// </summary>
    /// <param name="strPassword"></param>
    /// <returns></returns>
    public static string Md5(string strPassword)
    {
        MD5CryptoServiceProvider hashmd5;
        hashmd5 = new MD5CryptoServiceProvider();

        return BitConverter.ToString(hashmd5.ComputeHash(Encoding.Default.GetBytes(strPassword))).Replace("-", "").ToLower();
    }

    /// <summary>
    /// 比较是否相等
    /// </summary>
    /// <param name="source">要加密的串</param>
    /// <param name="entStr">加密之后的串</param>
    /// <returns>true:相等</returns>
    public static bool CompareHash(string source, string entStr)
    {
        if ((source == null) || (entStr == null))
        {
            return false;
        }
        return Md5(source).Equals(entStr);
    }


}

 

//3DES加密类,此加密算法可逆,经常用于对部分数据的加密及解密,例如需要进行网络传输的数据等。

public class DESCryptoHelper
{
    // Fields
    private SymmetricAlgorithm mCSP;
    private static readonly byte[] pIV = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 };
    private string sKey;

    // Methods
    public DESCryptoHelper()
    {
        this.sKey = "qJzGEh6hESZDVJeCnFPGuxzaiB7NLQM3";
        this.mCSP = new TripleDESCryptoServiceProvider();
    }

    public DESCryptoHelper(string key)
    {
        this.mCSP = new TripleDESCryptoServiceProvider();
        this.sKey = key;
    }

    public string DesDecrypt(string Value)
    {
        TripleDES edes = TripleDES.Create();
        edes.Mode = CipherMode.CBC;
        edes.Padding = PaddingMode.PKCS7;
        edes.Key = Convert.FromBase64String(this.sKey);
        this.mCSP.IV = pIV;
        ICryptoTransform transform = edes.CreateEncryptor(edes.Key, edes.IV);
        byte[] buffer = Convert.FromBase64String(Value);
        MemoryStream stream = new MemoryStream();
        CryptoStream stream2 = new CryptoStream(stream, transform, CryptoStreamMode.Write);
        stream2.Write(buffer, 0, buffer.Length);
        stream2.FlushFinalBlock();
        stream2.Close();
        return Encoding.UTF8.GetString(stream.ToArray());
    }

    public string DesEncrypt(string Value)
    {
        TripleDES edes = TripleDES.Create();
        edes.Mode = CipherMode.CBC;
        edes.Padding = PaddingMode.PKCS7;
        edes.Key = Convert.FromBase64String(this.sKey);
        this.mCSP.IV = pIV;
        ICryptoTransform transform = edes.CreateEncryptor(edes.Key, edes.IV);
        byte[] bytes = Encoding.UTF8.GetBytes(Value);
        MemoryStream stream = new MemoryStream();
        CryptoStream stream2 = new CryptoStream(stream, transform, CryptoStreamMode.Write);
        stream2.Write(bytes, 0, bytes.Length);
        stream2.FlushFinalBlock();
        stream2.Close();
        return Convert.ToBase64String(stream.ToArray());
    }

    /// <summary>
    /// 得到解密之后的字符串
    /// </summary>
    /// <param name="Value"></param>
    /// <returns></returns>
    public string GetDesString(string Value)
    {
        this.mCSP.Key = Convert.FromBase64String(this.sKey);
        this.mCSP.IV = pIV;
        this.mCSP.Mode = CipherMode.CBC;
        this.mCSP.Padding = PaddingMode.PKCS7;
        ICryptoTransform transform = this.mCSP.CreateDecryptor(this.mCSP.Key, this.mCSP.IV);
        byte[] buffer = Convert.FromBase64String(Value);
        MemoryStream stream = new MemoryStream();
        CryptoStream stream2 = new CryptoStream(stream, transform, CryptoStreamMode.Write);
        stream2.Write(buffer, 0, buffer.Length);
        stream2.FlushFinalBlock();
        stream2.Close();
        this.mCSP.Clear();
        return Encoding.UTF8.GetString(stream.ToArray());
    }


    /// <summary>
    /// 得到加密之后的口字符串
    /// </summary>
    /// <param name="Value"></param>
    /// <returns></returns>
    public string GetEncString(string Value)
    {
        this.mCSP.Key = Convert.FromBase64String(this.sKey);
        this.mCSP.IV = pIV;
        this.mCSP.Mode = CipherMode.CBC;
        this.mCSP.Padding = PaddingMode.PKCS7;
        ICryptoTransform transform = this.mCSP.CreateEncryptor(this.mCSP.Key, this.mCSP.IV);
        byte[] bytes = Encoding.UTF8.GetBytes(Value);
        MemoryStream stream = new MemoryStream();
        CryptoStream stream2 = new CryptoStream(stream, transform, CryptoStreamMode.Write);
        stream2.Write(bytes, 0, bytes.Length);
        stream2.FlushFinalBlock();
        stream2.Close();
        this.mCSP.Clear();
        return Convert.ToBase64String(stream.ToArray());
    }
}

【顶级EI完美复现】电力系统碳排放流的计算方法【IEEE 14节点】(Matlab代码实现)内容概要:本文介绍了名为《【顶级EI完美复现】电力系统碳排放流的计算方法【IEEE 14节点】(Matlab代码实现)》的技术文档,核心内容是基于IEEE 14节点电力系统模型,利用Matlab实现碳排放流的精确计算方法。该方法通过建立电力系统中各节点的功率流动与碳排放之间的映射关系,实现对电能传输过程中碳足迹的追踪与量化分析,属于电力系统低碳调度与碳流管理领域的关键技术。文中强调“顶级EI完美复现”,表明其算法和仿真结果具有较高的学术严谨性和可重复性,适用于科研验证与教学演示。; 适合人群:电力系统、能源与动力工程、电气工程及其自动化等相关专业的研究生、科研人员以及从事电力系统低碳化、碳排放核算工作的技术人员。; 使用场景及目标:①用于电力系统碳排放流理论的学习与仿真验证;②支撑含新能源接入的电力系统低碳调度、碳交易、绿色电力溯源等课题的研究;③为撰写高水平学术论文(如EI/SCI期刊)提供可靠的代码基础和技术参考。; 阅读建议:读者应具备电力系统分析、Matlab编程的基础知识,建议结合电力系统潮流计算、节点导纳矩阵等前置知识进行学习,并通过调整系统参数和运行方式,深入理解碳排放流的分布规律与影响因素。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值