C#判断密码强度的方法
C#判断密码强度的方法
发布时间:2016-12-28 来源:查字典编辑
摘要:本文实例讲述了C#判断密码强度的方法。分享给大家供大家参考。具体如下:1.关于密码强度密码强度有强弱之分,包含数字、字母和其他符号三者且长度...

本文实例讲述了C#判断密码强度的方法。分享给大家供大家参考。具体如下:

1.关于密码强度

密码强度有强弱之分,包含数字、字母和其他符号三者且长度不小于10的密码被称为强密码,只有其中一者或长度不大于6的密码是弱密码,其他密码是中等强度密码。

2.判断密码强弱的函数

/// <summary> /// 密码强度 /// </summary> private enum Strength { Invalid = 0, //无效密码 Weak = 1, //低强度密码 Normal = 2, //中强度密码 Strong = 3 //高强度密码 }; /// <summary> /// 计算密码强度 /// </summary> /// <param name="password">密码字符串</param> /// <returns></returns> private static Strength PasswordStrength(string password) { //空字符串强度值为0 if (password == "") return Strength.Invalid; //字符统计 int iNum = 0, iLtt = 0, iSym = 0; foreach (char c in password) { if (c >= '0' && c <= '9') iNum++; else if (c >= 'a' && c <= 'z') iLtt++; else if (c >= 'A' && c <= 'Z') iLtt++; else iSym++; } if (iLtt == 0 && iSym == 0) return Strength.Weak; //纯数字密码 if (iNum == 0 && iLtt == 0) return Strength.Weak; //纯符号密码 if (iNum == 0 && iSym == 0) return Strength.Weak; //纯字母密码 if (password.Length <= 6) return Strength.Weak; //长度不大于6的密码 if (iLtt == 0) return Strength.Normal; //数字和符号构成的密码 if (iSym == 0) return Strength.Normal; //数字和字母构成的密码 if (iNum == 0) return Strength.Normal; //字母和符号构成的密码 if (password.Length <= 10) return Strength.Normal; //长度不大于10的密码 return Strength.Strong; //由数字、字母、符号构成的密码 }

3.Main函数调用

static void Main(string[] args) { string sPassword; while (true) { Console.WriteLine("请输入一个密码:"); sPassword = Console.ReadLine(); switch (PasswordStrength(sPassword)) { case Strength.Invalid: Console.WriteLine("无效密码n"); break; case Strength.Weak: Console.WriteLine("低强度密码n"); break; case Strength.Normal: Console.WriteLine("中强度密码n"); break; case Strength.Strong: Console.WriteLine("高强度密码n"); break; } } }

4.运行结果:

C#判断密码强度的方法1

希望本文所述对大家的C#程序设计有所帮助。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新C#教程学习
热门C#教程学习
编程开发子分类