c#窗体实现验证码

          在form窗体登录时,使用一些验证码,感觉挺有意思的。

    首先在窗体上放置上一个lable:请输入验证码。再放上一个text文本框,name=“txtValidCode”;然后在放入一个pictureBox。name="picValidCode";在放入一个按钮,text=“提交”。

   


     在同层中加入一个类。ValidCode ,代码如下。

using System;

using System.Collections.Generic;

using System.Text;

using System.IO;

using System.Drawing;

using System.Drawing.Drawing2D;



namespace 实验1
{

    public class ValidCode
    {

        #region Private Fields

        private const double PI = 3.1415926535897932384626433832795;

        private const double PI2 = 6.283185307179586476925286766559;

        //private readonly int _wordsLen = 4; 

        private int _len;

        private CodeType _codetype;

        private readonly Single _jianju = (float)18.0;

        private readonly Single _height = (float)24.0;

        private string _checkCode;

        #endregion

        #region Public Property

        public string CheckCode
        {

            get
            {

                return _checkCode;

            }

        }

        #endregion

        #region Constructors

        /// <summary> 

        /// public constructors 

        /// </summary> 

        /// <param name="len"> 验证码长度 </param> 

        /// 
  • 10
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
下面是C#窗体实现RSA签名验证的示例代码: ```csharp using System; using System.Security.Cryptography; using System.Text; using System.Windows.Forms; namespace RSASignatureVerification { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btnSign_Click(object sender, EventArgs e) { try { // 生成RSA密钥对 RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); string privateKey = rsa.ToXmlString(true); string publicKey = rsa.ToXmlString(false); // 使用私钥对消息进行签名 byte[] data = Encoding.UTF8.GetBytes(txtMessage.Text); byte[] signature = SignData(data, privateKey); // 显示签名结果 txtSignature.Text = Convert.ToBase64String(signature); // 将私钥和公钥保存到文件中 SaveKeyToFile(privateKey, "privateKey.txt"); SaveKeyToFile(publicKey, "publicKey.txt"); } catch (Exception ex) { MessageBox.Show(ex.Message); } } private void btnVerify_Click(object sender, EventArgs e) { try { // 从文件中读取公钥 string publicKey = LoadKeyFromFile("publicKey.txt"); // 使用公钥对签名进行验证 byte[] data = Encoding.UTF8.GetBytes(txtMessage.Text); byte[] signature = Convert.FromBase64String(txtSignature.Text); bool result = VerifyData(data, signature, publicKey); // 显示验证结果 if (result) { MessageBox.Show("签名验证成功"); } else { MessageBox.Show("签名验证失败"); } } catch (Exception ex) { MessageBox.Show(ex.Message); } } // 使用私钥对数据进行签名 private byte[] SignData(byte[] data, string privateKey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); rsa.FromXmlString(privateKey); return rsa.SignData(data, new SHA256CryptoServiceProvider()); } // 使用公钥对签名进行验证 private bool VerifyData(byte[] data, byte[] signature, string publicKey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); rsa.FromXmlString(publicKey); return rsa.VerifyData(data, new SHA256CryptoServiceProvider(), signature); } // 将密钥保存到文件中 private void SaveKeyToFile(string key, string fileName) { using (System.IO.StreamWriter sw = new System.IO.StreamWriter(fileName)) { sw.Write(key); } } // 从文件中读取密钥 private string LoadKeyFromFile(string fileName) { using (System.IO.StreamReader sr = new System.IO.StreamReader(fileName)) { return sr.ReadToEnd(); } } } } ``` 该代码实现了RSA签名的生成和验证功能,并将私钥和公钥保存到文件中。在签名生成时,使用`RSACryptoServiceProvider`类生成RSA密钥对,并使用私钥对消息进行签名。在签名验证时,从文件中读取公钥,并使用公钥对签名进行验证。在保存密钥到文件中时,使用`StreamWriter`类将密钥写入文件。在读取密钥时,使用`StreamReader`类从文件中读取密钥。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值