Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Lokale string Variable als Zwischenspeicher benötigt (https://www.delphipraxis.net/208609-lokale-string-variable-als-zwischenspeicher-benoetigt.html)

TurboMagic 25. Aug 2021 15:06

Lokale string Variable als Zwischenspeicher benötigt
 
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;

jaenicke 25. Aug 2021 23:37

AW: Lokale string Variable als Zwischenspeicher benötigt
 
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?

himitsu 26. Aug 2021 10:41

AW: Lokale string Variable als Zwischenspeicher benötigt
 
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


TurboMagic 27. Aug 2021 08:42

AW: Lokale string Variable als Zwischenspeicher benötigt
 
Zitat:

Zitat von jaenicke (Beitrag 1493917)
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.


Alle Zeitangaben in WEZ +1. Es ist jetzt 04:36 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