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
GELÖST

Userinformationen auslesen

Frage Entwicklung VB for Applications

Mitglied: Cyberops

Cyberops (Level 1) - Jetzt verbinden

10.03.2008, aktualisiert 14:02 Uhr, 7646 Aufrufe, 2 Kommentare

Userdaten anhand des Usernames aus der AD auslesen.

Hallo zusammen.

Ich habe folgendes Problem:
Ich brauche den Anzeigenamen (displayName) des Users, der auf der Maschine angemeldet ist.

Die einzigste Informationen die ich habe, ist der Username und die Domäne, die in den Umgebungsvariablen hinterlegt sind.

Ich hoffe mir kann da jemand weiterhelfen.

Ich habe es so probiert,
ohne erfolg

01.
Public Sub User_Info() 
02.
     
03.
    On Error Resume Next 
04.
     
05.
    strUser = Environ$("USERNAME") 
06.
 
07.
    'ConnectionString 
08.
    Set objConnection = CreateObject("ADODB.Connection") 
09.
    Set objCommand = CreateObject("ADODB.Command") 
10.
    objConnection.Provider = "ADsDSOObject" 
11.
    objConnection.Open "Active Directory Provider" 
12.
    Set objCommand.ActiveConnection = objConnection 
13.
 
14.
    objCommand.Properties("Page Size") = 1000 
15.
    objCommand.Properties("Searchscope") = ADS_SCOPE_SUBTREE 
16.
     
17.
    'User- Daten importieren 
18.
    objCommand.CommandText = _ 
19.
        "SELECT displayName FROM 'LDAP://dc=firma,dc=com' WHERE SamAccountName = " & strUser 
20.
    Set objRecordSet = objCommand.Execute 
21.
     
22.
    strDN = objRecordSet.displayName 
23.
    MsgBox strDN 
24.
 
25.
End Sub
Merci schonmal für eure Hilfe
Mitglied: Logan000
10.03.2008 um 13:48 Uhr
Worunter läuft diese procedur? VBA, VBS?
Environ$ funktioniert soweit ich weiss unter vbs nicht.

Hier mal als vbs skript:
01.
Domain= "MyDomain" 
02.
DomSuffix= "de" 
03.
 
04.
Set WshNetwork = Wscript.CreateObject("Wscript.Network") 
05.
strUserName = LCase(WshNetwork.Username) 
06.
 
07.
 
08.
Set objConnection = CreateObject("ADODB.Connection") 
09.
objConnection.Open "Provider=ADsDSOObject;" 
10.
  
11.
Set objCommand = CreateObject("ADODB.Command") 
12.
objCommand.ActiveConnection = objConnection 
13.
objCommand.CommandText = _ 
14.
    "<LDAP://dc=" & Domain & ",dc=" & DomSuffix & ">;(&(objectCategory=User)" & _ 
15.
         "(samAccountName=" & strUserName & "));samAccountName,displayname,sn;subtree" 
16.
   
17.
Set objRecordSet = objCommand.Execute 
18.
If objRecordset.RecordCount = 0 Then 
19.
    WScript.Echo "sAMAccountName: " & strUserName & " does not exist." 
20.
Else 
21.
	strDisplayname = objRecordset.fields(1).value 
22.
End If 
23.
objConnection.Close 
24.
 
25.
WScript.Echo  strDisplayname
Bitte warten ..
Mitglied: Cyberops
10.03.2008 um 14:02 Uhr
Merci Logan000

Das war genau das was ich gesucht habe.
Musste es halt für VBA noch ein wenig anpassen,
funktioniert aber einwandfrei

01.
Domain= "MyDomain" 
02.
DomSuffix= "de" 
03.
 
04.
strUserName = Environ$("USERNAME") 
05.
 
06.
Set objConnection = CreateObject("ADODB.Connection") 
07.
objConnection.Open "Provider=ADsDSOObject;" 
08.
  
09.
Set objCommand = CreateObject("ADODB.Command") 
10.
objCommand.ActiveConnection = objConnection 
11.
objCommand.CommandText = _ 
12.
    "<LDAP://dc=" & Domain & ",dc=" & DomSuffix & ">;(&(objectCategory=User)" & _ 
13.
         "(samAccountName=" & strUserName & "));samAccountName,displayname,sn;subtree" 
14.
   
15.
Set objRecordSet = objCommand.Execute 
16.
If objRecordset.RecordCount = 0 Then 
17.
    MsgBox "sAMAccountName: " & strUserName & " does not exist." 
18.
Else 
19.
	strDisplayname = objRecordset.fields(1).value 
20.
End If 
21.
objConnection.Close 
22.
 
23.
MsgBox  strDisplayname
Danke nochmals für die rasche Hilfe.

Gruss,
Cyberops
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
gelöst Batch: CPU-Auslastung eines Prozesses auslesen und als Variable definieren (3)

Frage von tralveller zum Thema Batch & Shell ...

Batch & Shell
gelöst Auslesen und Vergleichen Zweiter CSV Dateien Powershell (7)

Frage von Hainoon zum Thema Batch & Shell ...

Batch & Shell
gelöst Laufwerkgröße der Clients auslesen (6)

Frage von michi-ffm zum Thema Batch & Shell ...

Batch & Shell
String Zeichenpaare auslesen und bearbeiten (6)

Frage von ahstax zum Thema Batch & Shell ...

Neue Wissensbeiträge
Google Android

Cyanogenmod alternative Downloadquelle

(5)

Tipp von Lochkartenstanzer zum Thema Google Android ...

Batch & Shell

Batch als Dienst bei Systemstart ohne Anmeldung ausführen

(5)

Tipp von tralveller zum Thema Batch & Shell ...

Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

(1)

Tipp von gdconsult zum Thema Sicherheits-Tools ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
gelöst Statische Routen mit Shorewall, ISC-DHCP Server konfigurieren für Android Devices (24)

Frage von terminator zum Thema LAN, WAN, Wireless ...

Server
gelöst Wie erkennen, dass nur deutsche IPs Zugang zu einer Website haben? (22)

Frage von Coreknabe zum Thema Server ...

Hardware
16-20 Port POE Switch mit VLAN (19)

Frage von thomasreischer zum Thema Hardware ...

Windows Server
Exchange HyperV Prozessorlast (18)

Frage von theoberlin zum Thema Windows Server ...