legongju.com
我们一直在努力
2025-01-06 18:50 | 星期一

如何在c#中实现对称加密

在C#中实现对称加密,你可以使用.NET框架自带的System.Security.Cryptography命名空间中的类。以下是一个使用AES算法的简单示例:

  1. 首先,确保你已经安装了.NET Framework或.NET Core。

  2. 创建一个新的C#控制台应用程序项目。

  3. 在项目中添加以下命名空间引用:

using System;
using System.Text;
using System.Security.Cryptography;
  1. 在Main方法中,编写以下代码:
class Program
{
    static void Main(string[] args)
    {
        string plaintext = "Hello, World!";
        string key = "ThisIsASecretKey!";
        string ciphertext = Encrypt(plaintext, key);
        Console.WriteLine("Plaintext: " + plaintext);
        Console.WriteLine("Ciphertext: " + ciphertext);

        string decryptedText = Decrypt(ciphertext, key);
        Console.WriteLine("Decrypted Text: " + decryptedText);
    }

    static byte[] Encrypt(string plaintext, string key)
    {
        using (Aes aesAlg = Aes.Create())
        {
            byte[] keyBytes = Encoding.UTF8.GetBytes(key);
            byte[] initVectorBytes = Encoding.UTF8.GetBytes("ThisIsASecretInitVector!");

            aesAlg.Key = keyBytes;
            aesAlg.IV = initVectorBytes;

            ICryptoTransform encryptor = aesAlg.CreateEncryptor(aesAlg.Key, aesAlg.IV);

            using (var msEncrypt = new System.IO.MemoryStream())
            {
                using (var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
                {
                    using (var swEncrypt = new StreamWriter(csEncrypt))
                    {
                        swEncrypt.Write(plaintext);
                    }
                }
                return msEncrypt.ToArray();
            }
        }
    }

    static string Decrypt(byte[] cipherText, string key)
    {
        using (Aes aesAlg = Aes.Create())
        {
            byte[] keyBytes = Encoding.UTF8.GetBytes(key);
            byte[] initVectorBytes = Encoding.UTF8.GetBytes("ThisIsASecretInitVector!");

            aesAlg.Key = keyBytes;
            aesAlg.IV = initVectorBytes;

            ICryptoTransform decryptor = aesAlg.CreateDecryptor(aesAlg.Key, aesAlg.IV);

            using (var msDecrypt = new System.IO.MemoryStream(cipherText))
            {
                using (var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read))
                {
                    using (var srDecrypt = new StreamReader(csDecrypt))
                    {
                        return srDecrypt.ReadToEnd();
                    }
                }
            }
        }
    }
}

在这个示例中,我们使用了AES加密算法,并创建了一个简单的控制台应用程序来加密和解密字符串。请注意,为了简化示例,我们使用了一个固定的密钥和初始化向量(IV)。在实际应用中,你应该使用更安全的方式来生成和存储密钥和IV。

未经允许不得转载 » 本文链接:https://www.legongju.com/article/85576.html

相关推荐

  • C++与Flask结合的实践案例有哪些

    C++与Flask结合的实践案例有哪些

    目前没有直接找到C++与Flask结合的实践案例。Flask是一个用Python编写的轻量级Web应用框架,而C++和Python是两种不同的编程语言,它们之间的直接结合在实践中非常...

  • 如何在C++中使用Flask框架

    如何在C++中使用Flask框架

    Flask 是一个 Python Web 开发框架,而 C++ 是一种不同的编程语言 创建一个 Flask 应用: from flask import Flask, request, jsonify
    app = Flask(__name_...

  • 如何正确编写C++头文件

    如何正确编写C++头文件

    在C++中,头文件(.h或.hpp)用于声明函数、类和模板等代码实体 包含保护:为了防止头文件被多次包含,应使用预处理器指令#pragma once或者#ifndef/#define/#end...

  • 如何在C++中实现Flask的异步处理

    如何在C++中实现Flask的异步处理

    在 C++ 中,我们可以使用 Boost.Asio 库来实现类似于 Flask 的异步处理。Boost.Asio 是一个高性能的 C++ 网络编程库,它提供了异步 I/O 操作、协议无关的设计以及...

  • c#中对称加密算法有哪些

    c#中对称加密算法有哪些

    在C#中,对称加密算法主要包括以下几种: DES(Data Encryption Standard):这是一种分组密码算法,使用56位密钥对数据进行加密。虽然DES在过去被广泛应用,但现...

  • c#中cookie与session的区别是什么

    c#中cookie与session的区别是什么

    在C#中,Cookie和Session都是用于在客户端和服务器之间进行通信的机制,但它们之间存在一些关键区别: 存储位置:Cookie数据存储在客户端(即用户的浏览器)上,...

  • 如何在c#中禁用cookie

    如何在c#中禁用cookie

    在C#中禁用Cookie,您需要执行以下步骤: 首先,确保已安装并引用了System.Web.Cookie命名空间。 using System.Web.Cookie; 接下来,创建一个自定义CookieHandle...

  • c#中cookie的域如何设置

    c#中cookie的域如何设置

    在C#中,设置Cookie的域可以使用HttpCookie对象的Domain属性。以下是一个示例:
    // 创建一个新的HttpCookie对象
    HttpCookie myCookie = new HttpCooki...