Bu şifre her kullanıcı için sona erinceye kadar kalan süreyi öğrenmek için hile yapmak gerekir:
private static TimeSpan GetTimeRemainingUntilPasswordExpiration(string domain, string userName)
{
using (var userEntry = new System.DirectoryServices.DirectoryEntry(string.Format("WinNT://{0}/{1},user", domain, userName)))
{
var maxPasswordAge = (int)userEntry.Properties.Cast<System.DirectoryServices.PropertyValueCollection>().First(p => p.PropertyName == "MaxPasswordAge").Value;
var passwordAge = (int)userEntry.Properties.Cast<System.DirectoryServices.PropertyValueCollection>().First(p => p.PropertyName == "PasswordAge").Value;
return TimeSpan.FromSeconds(maxPasswordAge) - TimeSpan.FromSeconds(passwordAge);
}
}
Not: Eğer System.DirectoryServices
bir başvuru eklemeniz gerekir.
İnce Taneli Parola Politikaları'nda, bunları kullanıyorsanız veya kullanıyor olabilirseniz, buradaki etkenlerin olduğundan emin olun. Düşünmüyorum * sanıyor, ama burada kullanılan WinNT sağlayıcısını görmedim. –
Etki alanı ilkesi, grup ilkesi tarafından geçersiz kılındığında bu doğru bir çözümdür? –