zoukankan      html  css  js  c++  java
  • 步步为营-30-AES加密与解密

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows.Forms;
    using System.Security.Cryptography;
    
    namespace AES
    {
        public partial class Form1 : Form
        {
            
            public Form1()
            {
                InitializeComponent();            
            }
          
            private void btnEncrypt_Click(object sender, EventArgs e)
            {
               string toEncrypt = txtString.Text.Trim().ToString();
                string key = txtKey.Text.Trim().ToString();
                string iv = txtIv.Text.Trim().ToString();
               lblResult.Text = Encrypt(toEncrypt, key, iv);
            }
    
            private void btnDecrypt_Click(object sender, EventArgs e)
            {
                string toEncrypt = txtString.Text.Trim().ToString();
                string key = txtKey.Text.Trim().ToString();
                string iv = txtIv.Text.Trim().ToString();
                lblResult.Text = Decrypt(toEncrypt, key, iv);
            }
    
            public static string Encrypt(string toEncrypt, string key, string iv)
            {
    
    
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
                byte[] ivArray = UTF8Encoding.UTF8.GetBytes(iv);
                byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(toEncrypt);
    
                RijndaelManaged rDel = new RijndaelManaged();
                rDel.Key = keyArray;
                rDel.IV = ivArray;
                rDel.Mode = CipherMode.CBC;
                rDel.Padding = PaddingMode.Zeros;
    
                ICryptoTransform cTransform = rDel.CreateEncryptor();
                byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
    
                return Convert.ToBase64String(resultArray, 0, resultArray.Length);
            }
    
            public static string Decrypt(string toDecrypt, string key, string iv)
            {
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(key);
                byte[] ivArray = UTF8Encoding.UTF8.GetBytes(iv);
                byte[] toEncryptArray = Convert.FromBase64String(toDecrypt);
    
                RijndaelManaged rDel = new RijndaelManaged();
                rDel.Key = keyArray;
                rDel.IV = ivArray;
                rDel.Mode = CipherMode.CBC;
                rDel.Padding = PaddingMode.Zeros;
    
                ICryptoTransform cTransform = rDel.CreateDecryptor();
                byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
    
                return UTF8Encoding.UTF8.GetString(resultArray);
            }
        }
    }
    View Code
  • 相关阅读:
    c语言寒假大作战02
    C语言寒假大作战01
    C语言I作业12
    C语言I博客作业11
    C语言I博客作业10
    C语言ll作业01
    C语言寒假大作战04
    C语言寒假大作战03
    C语言寒假大作战02
    C语言寒假大作战01
  • 原文地址:https://www.cnblogs.com/YK2012/p/6746745.html
Copyright © 2011-2022 走看看