在好例子网,分享、交流、成长!
您当前所在位置:首页C# 开发实例常用C#方法 → 常用加密解密工具(源码)

常用加密解密工具(源码)

常用C#方法

下载此实例
  • 开发语言:C#
  • 实例大小:0.07M
  • 下载次数:64
  • 浏览次数:496
  • 发布时间:2021-05-12
  • 实例类别:常用C#方法
  • 发 布 人:ZINGU
  • 文件格式:.rar
  • 所需积分:2
 相关标签: 加密解密 常用 解密 加密

实例介绍

【实例简介】

MD5加密

AES加密/解密

DES加密/解密

RSA加密/解密

【实例截图】

from clipboard


from clipboard

【核心代码】

  public Form1()
        {
            InitializeComponent();
        }
        /// <summary>
        /// MD5转换
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnMD5_Click(object sender, EventArgs e)
        {
            if (!string.IsNullOrWhiteSpace(rtbMd5Base.Text))
            {
                rtbMd5.Text = SHAHelper.SHAmd5Encrypt(rtbMd5Base.Text);
            }
        }
        /// <summary>
        /// md5清空
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnMd5Clear_Click(object sender, EventArgs e)
        {
            rtbMd5.Text = "";
            rtbMd5Base.Text = "";
        }
        /// <summary>
        /// AES加密
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnAes_Click(object sender, EventArgs e)
        {
            if (txtAESKey.Text.Length != 32)
            {
                MessageBox.Show($@"秘钥长度必须32位,当前长度{txtAESKey.Text.Length}");
                return;
            }
            if (string.IsNullOrWhiteSpace(txtAESKey.Text) || string.IsNullOrWhiteSpace(rtbAesBase.Text))
            {
                MessageBox.Show(@"Please input key and text");
                return;
            }
            rtbAES.Text = AESHelper.AesEncrypt(rtbAesBase.Text, txtAESKey.Text);
        }
        /// <summary>
        /// AES解密
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btndeAES_Click(object sender, EventArgs e)
        {
            rtbdeAes.Text = "";
            if (txtDeKey.Text.Length != 32)
            {
                MessageBox.Show($@"秘钥长度必须32位,当前长度{txtDeKey.Text.Length}");
                return;
            }
            if (string.IsNullOrWhiteSpace(txtDeKey.Text) || string.IsNullOrWhiteSpace(rtbAES.Text))
            {
                MessageBox.Show(@"Please input  DeKey and text");
                return;
            }

            try
            {
                rtbdeAes.Text = AESHelper.AesDecrypt(rtbAES.Text, txtDeKey.Text);
            }
            catch (Exception exception)
            {
                MessageBox.Show(exception.Message);
            }

        }
        /// <summary>
        /// Des加密
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnDes_Click(object sender, EventArgs e)
        {
            if (txtDESkey.Text.Length != 8 || txtDesVar.Text.Length != 8)
            {
                MessageBox.Show($@"秘钥/向量必须8位,当前秘钥长度{txtDESkey.Text.Length}");
            }
            if (string.IsNullOrWhiteSpace(txtDESkey.Text) || string.IsNullOrWhiteSpace(txtDesVar.Text) || string.IsNullOrWhiteSpace(rtbDesBase.Text))
            {
                MessageBox.Show(@"请输入秘钥、向量及待加密文本");
            }
            DESHelper._KEY = System.Text.Encoding.Default.GetBytes(txtDESkey.Text);
            DESHelper._IV = System.Text.Encoding.Default.GetBytes(txtDesVar.Text);
            rtbDES.Text = DESHelper.DesEncrypt(rtbDesBase.Text);
        }
        /// <summary>
        /// des解密
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnDEDes_Click(object sender, EventArgs e)
        {
            if (txtDEDES.Text.Length != 8 || txtDesVar.Text.Length != 8)
            {
                MessageBox.Show($@"秘钥/向量必须8位,当前秘钥长度{txtDESkey.Text.Length}");
            }
            if (string.IsNullOrWhiteSpace(txtDEDES.Text) || string.IsNullOrWhiteSpace(txtDeVar.Text) || string.IsNullOrWhiteSpace(rtbDES.Text))
            {
                MessageBox.Show(@"请输入秘钥、向量及待解密文本");
            }
            DESHelper._KEY = System.Text.Encoding.Default.GetBytes(txtDEDES.Text);
            DESHelper._IV = System.Text.Encoding.Default.GetBytes(txtDeVar.Text);
            try
            {
                DES.Text = DESHelper.DesDecrypt(rtbDES.Text);
            }
            catch (Exception exception)
            {
                MessageBox.Show(exception.Message);
            }

        }

        /// <summary>
        /// RES生成秘钥
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnCreateKey_Click(object sender, EventArgs e)
        {
            string path = "";
            FolderBrowserDialog dialog = new FolderBrowserDialog();
            dialog.Description = @"请选择保存文件夹";
            dialog.SelectedPath = path;
            //dialog.RootFolder = Environment.SpecialFolder.Programs;
            if (dialog.ShowDialog() == DialogResult.OK)
            {
                string foldPath = dialog.SelectedPath;
                RSAHelper.GenerateKeys(foldPath);
                txtPub.Text = Path.Combine(foldPath, "RSA.Pub");
                txtPri.Text = Path.Combine(foldPath, "RSA.Private");
            }
        }

        /// <summary>
        /// rsa加密
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void btnRSA_Click(object sender, EventArgs e)
        {
            //选择文件
            OpenFileDialog dialog = new OpenFileDialog();
            dialog.Multiselect = false ;//该值确定是否可以选择多个文件
            dialog.Title = @"请选择文件夹";
            dialog.Filter = @"Pub文件(*.Pub)|*.Pub";
            if (dialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
            {
                string file = dialog.FileName;
                rtbDeRSA.Text= RSAHelper.Encrypt(rtbRSABase.Text, file);     
            }
        }

        private void btnDERSA_Click(object sender, EventArgs e)
        {
            //选择文件
            OpenFileDialog dialog = new OpenFileDialog();
            dialog.Multiselect = false;//该值确定是否可以选择多个文件
            dialog.Title = @"请选择文件夹";
            dialog.Filter = @"Private文件(*.Private)|*.Private";
            if (dialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
            {
                string file = dialog.FileName;
                rtbDERSAold.Text = RSAHelper.Decrypt(rtbDeRSA.Text, file);
            }
        }

实例下载地址

常用加密解密工具(源码)

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警