2012-03-19 17 views

cevap

10

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.

+0

İ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. –

+1

Etki alanı ilkesi, grup ilkesi tarafından geçersiz kılındığında bu doğru bir çözümdür? –

İlgili konular