AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Lokale string Variable als Zwischenspeicher benötigt
Thema durchsuchen
Ansicht
Themen-Optionen

Lokale string Variable als Zwischenspeicher benötigt

Ein Thema von TurboMagic · begonnen am 25. Aug 2021 · letzter Beitrag vom 27. Aug 2021
Antwort Antwort
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.938 Beiträge
 
Delphi 12 Athens
 
#1

Lokale string Variable als Zwischenspeicher benötigt

  Alt 25. Aug 2021, 16:06
D10.4.2

Kann mir mal bitte jemand erklären, warum ich da unten die lokale ZwischenVariable s brauche, statt
das gleich dem Result zuzuweisen? Weise ich das dirket zu, bekomme ich nicht den Klartextnamen des Benutzers
aus dem AD, sondern den Loginnamen den GetCurrentUserLoginName liefert.

Delphi-Quellcode:
function TMainFormLogic.GetCurrentUserLoginName : string;
const
  cnMaxUserNameLen = 254;
var
  sUserName : string;
  dwUserNameLen : DWord;
begin
  dwUserNameLen := cnMaxUserNameLen-1;
  SetLength(sUserName, cnMaxUserNameLen);
  GetUserName(PChar(sUserName), dwUserNameLen);
  SetLength(sUserName, dwUserNameLen - 1);
  Result := sUserName;
end;

function TMainFormLogic.GetCurrentUserData: string;
var
  outUserInfo : TADSIUserInfo;
  ADCallResult : Boolean;
  CurrentUserName : string;
  CurrentDomainName : string;
  s : string;
begin
  Result := '';

  try
    Result := GetCurrentUserLoginName;

    CurrentUserName := ActiveDirectoryClient.GetCurrentUserName;
    CurrentDomainName := ActiveDirectoryClient.GetCurrentDomainName(CurrentUserName);

    ADCallResult := ActiveDirectoryClient.GetUserInfo(CurrentDomainName,
                                                           CurrentUserName,
                                                           outUserInfo);
    if ADCallResult then
    begin
      s := Copy(outUserInfo.UserName, 1, length(outUserInfo.UserName)) + ' / ' +
                         Copy(outUserInfo.Description, 1, length(outUserInfo.Description)) ;
      Result := s;
    end;
  except
    On e:Exception do
      log.SendException(cCategory, 'Fehler bei ActiveDirectory Aufruf: ' + e.Message, e);
  end;
end;
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
9.580 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Lokale string Variable als Zwischenspeicher benötigt

  Alt 26. Aug 2021, 00:37
Das sollte sich doch im Debugger zeigen. Vermutlich ist ADCallResult aus irgendeinem Grund False.

Besser wäre es auf jeden Fall so:
Delphi-Quellcode:
    if ADCallResult then
      Result := outUserInfo.UserName + ' / ' + outUserInfo.Description
    else
      Result := GetCurrentUserLoginName;
So wird Result := GetCurrentUserLoginName; nur ausgeführt, wenn es auch benötigt wird. Und wofür das Copy, wenn du ohnehin den ganzen String verwendest?
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.048 Beiträge
 
Delphi 12 Athens
 
#3

AW: Lokale string Variable als Zwischenspeicher benötigt

  Alt 26. Aug 2021, 11:41
Außerdem ist cnMaxUserNameLen total falsch.
* erstmal 254 statt 256
* und wird -1 statt +1 für die #0

Delphi-Strings haben zwar #0#0 eingebaut, aber dennoch könnte es somit einen Speicherüberlauf von 2 Chars / 4 Bytes geben.

Zitat:
Code:
/*
    This file contains constants used throughout the LAN Manager
    API header files. It should be included in any source file
    that is going to include other LAN Manager API header files or
    call a LAN Manager API.

    NOTE: Lengths of strings are given as the maximum lengths of the
    string in characters (not bytes). This does not include space for the
    terminating 0-characters. When allocating space for such an item,
    use the form:

        TCHAR username[UNLEN+1];
*/

#define UNLEN      256                 // Maximum user name length
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.938 Beiträge
 
Delphi 12 Athens
 
#4

AW: Lokale string Variable als Zwischenspeicher benötigt

  Alt 27. Aug 2021, 09:42
Das sollte sich doch im Debugger zeigen. Vermutlich ist ADCallResult aus irgendeinem Grund False.

Besser wäre es auf jeden Fall so:
Delphi-Quellcode:
    if ADCallResult then
      Result := outUserInfo.UserName + ' / ' + outUserInfo.Description
    else
      Result := GetCurrentUserLoginName;
So wird Result := GetCurrentUserLoginName; nur ausgeführt, wenn es auch benötigt wird. Und wofür das Copy, wenn du ohnehin den ganzen String verwendest?
Ok, der Code wäre besser, nur: ADCallResult war in den Fällen nicht false.
Innerhalb der Methode war Result das, was ich erwartet hätte, auf der Aufruferseite war der String dann aber immer
leer oder so und ich weiß nicht warum. Daher meine Lösung mit dem Copy.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:43 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz