Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

Error abfangen

Frage Entwicklung VB for Applications

Mitglied: LordShelmchen

LordShelmchen (Level 1) - Jetzt verbinden

19.05.2008, aktualisiert 28.05.2008, 6456 Aufrufe, 2 Kommentare

Moin Moin,

ich habe ein kleines VB Script geschrieben, damit Benutzer auf einem Terminalserver (Citrix Published App) ihr Domänenkennwort ändern können.

Hier der entsprechende Teil des Scriptes:

01.
'Verbindung zum AD aufbauen 
02.
Set objConnection = CreateObject("ADODB.Connection") 
03.
Set objCommand    = CreateObject("ADODB.Command") 
04.
Set objRootDSE = GetObject("LDAP://RootDSE") 
05.
strDNSDomain = objRootDSE.Get("defaultNamingContext") 
06.
objConnection.Open "Provider=ADsDSOObject;" 
07.
objCommand.ActiveConnection = objConnection 
08.
objCommand.CommandText = "<LDAP://" & strDNSDomain & ">;(&(objectCategory=User)(samAccountName=" & samAccountName & "));distinguishedName;subtree" 
09.
 
10.
' Kennwort und Kennwort aendern setzen, wenn der Benutzer gefunden wurde 
11.
Set objRecordset = objCommand.Execute 
12.
If objRecordset.RecordCount = 1 Then     
13.
	Set objUser = GetObject _ 
14.
	    ("LDAP://" & objRecordSet.fields("distinguishedName")) 
15.
	objUser.ChangePassword AltesKennwort, NeuesKennwort 
16.
 
17.
end If
Die entsprechenden Variablen werden vorher mittels Inputbox gefüllt.

Wie kann ich da jetzt Fehler abfangen?

Hier kann es dem Benutzer passieren das er ein nicht erlaubtes Kennwort verwendet (diverse Settings aktiv). Dann bricht die Anwendung direkt ab. Jedoch kann ich den Returncode nicht abfangen, das Script wird einfach beendet.

Grüße
LordShelmchen
Mitglied: SvenGuenter
21.05.2008 um 16:41 Uhr
01.
On Error Goto Errorhandler 
02.
'Verbindung zum AD aufbauen 
03.
Set objConnection = CreateObject("ADODB.Connection") 
04.
Set objCommand    = CreateObject("ADODB.Command") 
05.
Set objRootDSE = GetObject("LDAP://RootDSE") 
06.
strDNSDomain = objRootDSE.Get("defaultNamingContext") 
07.
objConnection.Open "Provider=ADsDSOObject;" 
08.
objCommand.ActiveConnection = objConnection 
09.
objCommand.CommandText = "<LDAP://" & strDNSDomain & ">;(&(objectCategory=User)(samAccountName=" & samAccountName & "));distinguishedName;subtree" 
10.
 
11.
' Kennwort und Kennwort aendern setzen, wenn der Benutzer gefunden wurde 
12.
Set objRecordset = objCommand.Execute 
13.
If objRecordset.RecordCount = 1 Then     
14.
	Set objUser = GetObject _ 
15.
	    ("LDAP://" & objRecordSet.fields("distinguishedName")) 
16.
	objUser.ChangePassword AltesKennwort, NeuesKennwort 
17.
 
18.
end If 
19.
 
20.
errorhandler: 
21.
msgbox(Err.Description) 
22.
 
Gruß

Sven
Bitte warten ..
Mitglied: LordShelmchen
28.05.2008 um 15:31 Uhr
Danke für die Antwort,

aber leider bekomme ich dann einen

"C:\Programme\newpwdusr.vbs(24, 15) Kompilierungsfehler in Microsoft VBScript: Syntaxfehler"

Grüße
LordShelmchen
Bitte warten ..
Neuester Wissensbeitrag
DSL, VDSL

Telekom versendet automatische Kündigungen

(5)

Erfahrungsbericht von Voiper zum Thema DSL, VDSL ...

Ähnliche Inhalte
Verschlüsselung & Zertifikate
gelöst GnuTLS error -48 (1)

Frage von Chonta zum Thema Verschlüsselung & Zertifikate ...

Exchange Server
gelöst Test-ActiveSyncConnectivity Error nach neuem Zertifikat (22)

Frage von Driphex zum Thema Exchange Server ...

Windows Systemdateien
gelöst net 4.6.2 Error bei Installation (2)

Frage von leofabian zum Thema Windows Systemdateien ...

Heiß diskutierte Inhalte
Windows 7
gelöst BOOTMGR is missing (auch nach bootrec -RebuildBcd) (21)

Frage von Mipronimo zum Thema Windows 7 ...

Windows Userverwaltung
Windows Freigabe: Zugriff auf alle Ordner trotz Sicherheitseinstellungen (19)

Frage von Pandreas zum Thema Windows Userverwaltung ...

Exchange Server
gelöst MS Exchange 2016 - Basicconfig Fragen (16)

Frage von maddig zum Thema Exchange Server ...

Windows Server
gelöst Rechte als Admin vergeben - Zugriff verweigert (14)

Frage von Ghost108 zum Thema Windows Server ...