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#程序设计有所帮助。

以上是 C#判断密码强度的方法 的全部内容, 来源链接: utcz.com/z/339969.html

回到顶部