C#判断密码强度的方法
本文实例讲述了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#程序设计有所帮助。
赞 (0)