Top-Themen

Aktuelle Themen (A bis Z)

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

LDAP Suche in verschiedenen OUs

Frage Entwicklung VB for Applications

Mitglied: torben.dj

torben.dj (Level 1) - Jetzt verbinden

07.01.2015 um 09:53 Uhr, 730 Aufrufe, 4 Kommentare

Guten Morgen und ein frohes Neues,

im folgenden VBS-Skript kann ich anhand des angemeldeten Windows-Benutzers einen Adress-LDAP auslesen und mir zB Vorname, Nachname, Mailadresse etc ausgeben lassen.
Diese Angaben lasse ich in die Datei "Signatur.txt" schreiben.

01.
On Error Resume Next  
02.
Set fso = CreateObject("Scripting.FileSystemObject") 
03.
sZDatei = "Signatur.txt" 
04.
Set oZDatei = fso.OpenTextFile(sZDatei, 2, True) 
05.
Set WshNetwork = CreateObject("WScript.Network") 
06.
Username = WshNetwork.UserName 
07.
Set objUser = GetObject _  
08.
   ("LDAP://ldap.firma.de:389/uid=" &UserName &",ou=Abteilung,ou=Ort,ou=People,o=Firma,c=de") 
09.
oZDatei.Write "Mit freundlichen Grüßen" & vbCrLf & vbCrLf & vbCrLf 
10.
oZDatei.Write objUser.givenname &" " & objUser.sn & vbCrLf & vbCrLf 
11.
oZDatei.Write objUser.department & vbCrLf & vbCrLf 
12.
oZDatei.Write objUser.street & vbCrLf 
13.
oZDatei.Write objUser.postalcode &" " & objUser.l & vbCrLf & vbCrLf 
14.
oZDatei.Write "Tel.: " & objUser.telephonenumber & vbCrLf 
15.
oZDatei.Write "Mail: " & objUser.mail & vbCrLf 
16.
oZDatei.Close
Das Problem bei diesem Skript ist, dass ich wissen muss, in welcher Unter-OU sich der Benutzer befindet.
In diesem Fall ist es Firma --> People --> Ort --> Abteilung

Da ich selbst nicht sehr firm in VBS bin, nun die eigentliche Frage:

Wie kann ich das vorhandene Skritpt verändern damit nach der "uid" OU-übergreifend gesucht wird?

Vielen Dank schon mal für die Hilfe.

Bevor die Frage aufkommt, warum ich auf diesem Wege eine Signatur erstellen möchte,
die ausgelesenen Variablen werden in weiteren Skripten noch für benutzerspezifische Einrichtungen verwendet.

Mitglied: colinardo
07.01.2015, aktualisiert um 10:42 Uhr
Hallo torben.dj,
das machst du so:
01.
Const sZDatei = "Signatur.txt" 
02.
Set fso = CreateObject("Scripting.FileSystemObject") 
03.
Set objShell = CreateObject("Wscript.Shell") 
04.
 
05.
strUsername = objShell.ExpandEnvironmentStrings("%username%") 
06.
set objUser = FindAccount(strUsername) 
07.
if not objUser is nothing then 
08.
	Set oZDatei = fso.OpenTextFile(sZDatei, 2, True) 
09.
	oZDatei.Write "Mit freundlichen Grüßen" & vbCrLf & vbCrLf & vbCrLf 
10.
	oZDatei.Write objUser.givenname &" " & objUser.sn & vbCrLf & vbCrLf 
11.
	oZDatei.Write objUser.department & vbCrLf & vbCrLf 
12.
	oZDatei.Write objUser.street & vbCrLf 
13.
	oZDatei.Write objUser.postalcode &" " & objUser.l & vbCrLf & vbCrLf 
14.
	oZDatei.Write "Tel.: " & objUser.telephonenumber & vbCrLf 
15.
	oZDatei.Write "Mail: " & objUser.mail & vbCrLf 
16.
	oZDatei.Close 
17.
Else 
18.
	' Kein User mit diesem Loginnamen gefunden' 
19.
End if 
20.
 
21.
Function FindAccount(strUserName) 
22.
	On Error Resume Next 
23.
	Dim adoCommand, adoConnection 
24.
	Dim varBaseDN, varFilter 
25.
	Dim objRootDSE, varDNSDomain, strQuery, adoRecordset 
26.
 
27.
	Set adoCommand = CreateObject("ADODB.Command") 
28.
	Set adoConnection = CreateObject("ADODB.Connection") 
29.
	adoConnection.Provider = "ADsDSOObject" 
30.
	adoConnection.Open "Active Directory Provider" 
31.
	Set adoCommand.ActiveConnection = adoConnection 
32.
	 
33.
	' Search entire Active Directory domain. 
34.
	Set objRootDSE = GetObject("LDAP://RootDSE") 
35.
	 
36.
	varDNSDomain = objRootDSE.Get("defaultNamingContext") 
37.
	varBaseDN = "<LDAP://" & varDNSDomain & ">" 
38.
	 
39.
	' Filter for user objects. 
40.
	varFilter = "(&(objectCategory=person)(objectClass=user)(SamAccountName=" & strUserName & "))" 
41.
	 
42.
	' Construct the LDAP syntax query. 
43.
	adoCommand.CommandText = varBaseDN & ";" & varFilter & ";ADSPath;Subtree" 
44.
	adoCommand.Properties("Page Size") = 2 
45.
	adoCommand.Properties("Timeout") = 20 
46.
	adoCommand.Properties("Cache Results") = False 
47.
	Set adoRecordset = adoCommand.Execute 
48.
	adoRecordset.MoveFirst 
49.
 
50.
	If adoRecordset.RecordCount > 0 Then 
51.
		set FindAccount = GetObject(adoRecordset("ADSPath")) 
52.
	else 
53.
		set FindAccount = Nothing 
54.
	End If 
55.
	 
56.
	adoRecordset.Close 
57.
	adoConnection.Close 
58.
End Function
Grüße Uwe
Bitte warten ..
Mitglied: torben.dj
07.01.2015 um 12:05 Uhr
Danke für die Antwort.
Leider funktionieren die ActiveDirectory Befehle in diesem Fall nicht, da es sich bei dem
LDAP Adress-Server um ein altes Linux System handelt.
Bitte warten ..
Mitglied: colinardo
07.01.2015 um 12:12 Uhr
Zitat von torben.dj:
Leider funktionieren die ActiveDirectory Befehle in diesem Fall nicht, da es sich bei dem
LDAP Adress-Server um ein altes Linux System handelt.
lässt sich anpassen:
http://stackoverflow.com/questions/702998/connecting-to-openldap-server ...
Bitte warten ..
Mitglied: torben.dj
08.01.2015 um 08:21 Uhr
Manchmal sind es die kleinen Dinge, die den Unterschied machen.
Wenn ich einfach mal anstelle von LDAP nach OpenLDAP gesucht hätte, wäre ich schon schon schlauer.
Danke für den Link. Ich werde es mal versuchen.
Bitte warten ..
Ähnliche Inhalte
Sicherheits-Tools
Suche Tool oder Webseite welches bzw. welche mich über verschiedene Produktupdates informiert
Frage von KnorkatorSicherheits-Tools3 Kommentare

Hallo, gibt es eine Webseite oder ein Tool welches mit per Popup oder Mail informiert, wenn Adobe oder Sun ...

Microsoft Office
Excel - suchen und ersetzen für mehrere Formeln in verschiedenen Dateien
Frage von kilrathiMicrosoft Office

Hallo zusammen, ich weiß es gibt schon einige Fragen zu "suchen und ersetzen" in Excel, aber irgendwie passt Keine ...

Switche und Hubs
Suche 3 verschiedene 8-Port-Switche
gelöst Frage von 127944Switche und Hubs8 Kommentare

Moin, ich würde mein Problem gerne durch das Ziehen von neuen Kabeln lösen. Geht leider nicht. Ich muss nun ...

Windows Server
Verschieben von Usern und Computern im AD von Standard-Containern in OUs
gelöst Frage von knuddel256Windows Server2 Kommentare

Hallo zusammen, wir setzen in unserer Firma ein kleines Netzwerk bestehend aus einem WS 2012 Essentials und 7 Clients ...

Neue Wissensbeiträge
Perl

Perl hat heute Geburtstag: 30 Jahre Perl: Lange Gesichter zum Geburtstag

Information von Penny.Cilin vor 1 StundePerl1 Kommentar

Hallo, auch wenn es wenige wissen und noch weniger Leute es nutzen. Perl hat heute Geburtstag. 30 Jahre Perl ...

Sicherheit

Blackberry stirbt - Keine Updates für Priv mehr

Tipp von certifiedit.net vor 2 StundenSicherheit

Blackberry wird zu einer 08/15 Firma und geht wohl mehr und mehr den Weg, den HTC schon ging. Von ...

Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 2 TagenWindows 108 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 2 TagenSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Heiß diskutierte Inhalte
Batch & Shell
Kann man mit einer .txt Datei eine .bat Datei öffnen?
gelöst Frage von HelloWorldBatch & Shell20 Kommentare

Wie schon im Titel beschrieben würde ich gerne durch einfaches klicken auf eine Text oder Word Datei eine Batch ...

LAN, WAN, Wireless
WLAN Reichweite erhöhen mit neuer Antenne
gelöst Frage von gdconsultLAN, WAN, Wireless11 Kommentare

Hallo, ich besitze einen TL-WN722N USB-WLAN Dongle mit einer richtigen Antenne. Ich frage mich jetzt ob man die Reichweite ...

Router & Routing
Wieso kann ich den UPD 7000-9000 nicht freigeben?
Frage von Jayk0bRouter & Routing8 Kommentare

Router: Telekom W 723V Ports: UDP 7000-9000 Können nicht frei gegeben werden. Benutzgrund: Rocket League 7000 – 9000 UDP ...

Router & Routing
Fritzbox Gastnetz - exposed Host - zur Sophos IPTV
Frage von medikopterRouter & Routing8 Kommentare

Hallo zusammen, ich habe eine Frage bezüglich des Fritz box Gastzugangs an einer Sophos UTM Home. An liebsten wäre ...