C# 采用3DES-MAC进行签名 base64解码与编码

**

3DES-MAC

**

3DES-MAC(Triple Data Encryption Standard Message Authentication Code)是一种消息认证码(MAC)算法,用于验证消息的完整性和真实性。3DES-MAC使用了3DES(Triple Data Encryption Standard)加密算法的一部分来生成MAC值。以下是使用C#示例演示如何使用3DES-MAC签名一个消息:

首先,你需要确保在你的项目中引用了System.Security.Cryptography命名空间。

C# base64解码与编码

csharp 复制代码
using System;
using System.Security.Cryptography;
using System.Text;

class Program
{
    static void Main()
    {
        // 密钥和消息
        string key = "ThisIsASecretKey"; // 密钥长度必须是24字节(192位)
        string message = "Hello, World!";

        // 使用3DES-MAC签名消息
        string mac = Sign3DESMAC(key, message);
        Console.WriteLine("3DES-MAC 签名: " + mac);

        // 验证3DES-MAC签名
        bool isVerified = Verify3DESMAC(key, message, mac);
        if (isVerified)
        {
            Console.WriteLine("消息验证成功!");
        }
        else
        {
            Console.WriteLine("消息验证失败!");
        }
    }

    // 使用3DES-MAC签名消息
    static string Sign3DESMAC(string key, string message)
    {
        byte[] keyBytes = Encoding.UTF8.GetBytes(key);
        byte[] messageBytes = Encoding.UTF8.GetBytes(message);

        using (TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider())
        {
            des.Key = keyBytes;
            des.Mode = CipherMode.ECB; // 3DES-MAC通常使用ECB模式
            des.Padding = PaddingMode.PKCS7; // PKCS7填充

            using (HMACMD5 hmac = new HMACMD5(des.Key))
            {
                byte[] hashBytes = hmac.ComputeHash(messageBytes);
                return BitConverter.ToString(hashBytes).Replace("-", "").ToLower();
            }
        }
    }

    // 验证3DES-MAC签名
    static bool Verify3DESMAC(string key, string message, string macToVerify)
    {
        string calculatedMAC = Sign3DESMAC(key, message);
        return string.Equals(calculatedMAC, macToVerify, StringComparison.OrdinalIgnoreCase);
    }
}

在上述示例中,我们使用了3DES算法的一部分(通常是ECB模式)和HMAC-MD5散列算法来生成3DES-MAC签名。要记住,密钥的长度必须是24字节(192位),并且消息的签名可以使用Sign3DESMAC方法生成,并可以使用Verify3DESMAC方法验证。

请注意,3DES-MAC在实际应用中已经不太常见,因为现代加密标准更常用。如果安全性是关键问题,建议使用更强大的加密和签名算法,如HMAC-SHA256或更高级的算法。

base64解码与编码

csharp 复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace FT_Tools
{
    using System;
    using System.Text;

    class Base64
    {
        public static void MainTest()
        {
            // 要加密的原始字符串
            string originalText = "Hello, World!";

            // 加密成Base64字符串
            string base64EncodedText = EncodeBase64(originalText);
            Console.WriteLine("Base64 编码结果: " + base64EncodedText);

            // 解密Base64字符串
            string decodedText = DecodeBase64(base64EncodedText);
            Console.WriteLine("Base64 解码结果: " + decodedText);
        }

        // 使用Base64编码字符串
        public static string EncodeBase64(string text)
        {
            byte[] bytesToEncode = Encoding.UTF8.GetBytes(text);
            string encodedText = Convert.ToBase64String(bytesToEncode);
            return encodedText;
        }

        // 使用Base64解码字符串
        public static string DecodeBase64(string encodedText)
        {
            byte[] decodedBytes = Convert.FromBase64String(encodedText);
            string decodedText = Encoding.UTF8.GetString(decodedBytes);
            return decodedText;
        }
    }

}
相关推荐
广煜永不挂科35 分钟前
Devexpress.Dashboard的调用二义性
c#·express
java1234_小锋2 小时前
Elasticsearch中的节点(比如共20个),其中的10个选了一个master,另外10个选了另一个master,怎么办?
大数据·elasticsearch·jenkins
Elastic 中国社区官方博客2 小时前
Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
我的运维人生2 小时前
Elasticsearch实战应用:构建高效搜索与分析平台
大数据·elasticsearch·jenkins·运维开发·技术共享
初九之潜龙勿用3 小时前
C#校验画布签名图片是否为空白
开发语言·ui·c#·.net
endingCode3 小时前
45.坑王驾到第九期:Mac安装typescript后tsc命令无效的问题
javascript·macos·typescript
吾与谁归in4 小时前
【C#设计模式(13)——代理模式(Proxy Pattern)】
设计模式·c#·代理模式
吾与谁归in4 小时前
【C#设计模式(14)——责任链模式( Chain-of-responsibility Pattern)】
设计模式·c#·责任链模式
神仙别闹5 小时前
基于C#和Sql Server 2008实现的(WinForm)订单生成系统
开发语言·c#
soulteary5 小时前
突破内存限制:Mac Mini M2 服务器化实践指南
运维·服务器·redis·macos·arm·pika