C#判断密码强度

  

1.关于密码强度

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

/// <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; //由数字、字母、符号构成的密码
}
原文地址:https://www.cnblogs.com/axu92312/p/13690388.html