C# 最新手机号码段的号码验证实现

public static bool CheckPhoneIsAble(string input)
        {
            if (input.Length < 11)
            {
                return false;
            }
            //电信手机号码
            string dianxin = @"^1(33|49|53|73|74|77|80|81|89|99)\d{8}$";
            Regex regexDX = new Regex(dianxin);
            //联通手机号码
            string liantong = @"^1(30|31|32|45|46|55|56|66|71|75|76|85|86)\d{8}";
            Regex regexLT = new Regex(liantong);
            //移动手机号码
            string yidong = @"^1(34|35|36|37|38|39|47|48|50|51|52|57|58|59|72|78|82|83|84|87|88|98)\d{8}";
            Regex regexYD = new Regex(yidong);
            if (regexDX.IsMatch(input) || regexLT.IsMatch(input) || regexYD.IsMatch(input))
            {
                return true;
            }
            else
            {
                return false;
            }
        }

 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是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`类从文件中读取密钥。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值