AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

GetComputerName / GetUserName

Ein Thema von Luckie · begonnen am 25. Apr 2003 · letzter Beitrag vom 25. Apr 2003
Antwort Antwort
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#1

GetComputerName / GetUserName

  Alt 25. Apr 2003, 02:22
Microsoft ist doch immer wieder für eine Überraschung gut bzw. ich habe die Vermutung, sie wollen uns einfach nur ärgern. Folgendes habe ich in meiner SysInfo benutzt:

Delphi-Quellcode:
procedure TWinInfo.GetCompName;
const
  UNLEN = 256; // Maximum computer name length (LmCons.h)
var
  Size: DWORD;
begin
  Size := UNLEN + 1;
  SetLength(FComputerName, Size);
  if GetComputerName(PChar(FComputerName), Size) then
    SetLength(FComputerName, Size) // Size _ohne_ #0
  else
    FComputerName := '';
end;

procedure TWinInfo.GetUser;
const
  UNLEN = 256; // Maximum computer name length (LmCons.h)
var
  Size: DWORD;
begin
  Size := UNLEN + 1;
  SetLength(FUserName, Size);
  if GetUserName(PChar(FUserName), size) then
    SetLength(FUserName, Size-1) // Argh Size _mit_ #0
  else
    FUserName := '';
end;
Man beachte die Kommentare. Ich hatte erst GetCompName geschrieben und dann per Copy&Paste GetUser raus gemacht. Soweit kein Problem. Ich habe mich nur gewunder, warum nach dem Aufruf von GetUser nichts mehr ausgegeben wird. Beim Debuggen habe ich dann gesehen, dass GetCompName 'HAL9000' und GetUser 'Administrator'#0 liefert. Das dann natürlich die Ausgabe bei null terminierenden Strings zu ende ist, ist klar.

Und wenn man im PSDK nach liest, findet man auch folgendes:
Delphi-Quellcode:
BOOL GetComputerName(
  LPTSTR lpBuffer,
  LPDWORD lpnSize
);
Zitat:
lpnSize
[in, out] On input, specifies the size of the buffer, in TCHARs. On output, the number of TCHARs copied to the destination buffer, not including the terminating null character.
If the buffer is too small, the function fails and GetLastError returns ERROR_MORE_DATA. The lpnSize parameter specifies the size of the buffer required, not including the terminating null character.
Und:
Delphi-Quellcode:
BOOL GetUserName(
  LPTSTR lpBuffer,
  LPDWORD nSize
);
Zitat:
nSize
[in, out] On input, this variable specifies the size of the lpBuffer buffer, in TCHARs. On output, the variable receives the number of TCHARs copied to the buffer, including the terminating null character.
If lpBuffer is too small, the function fails and GetLastError returns ERROR_MORE_DATA. This parameter receives the required buffer size, including the terminating null character.
Kann mir mal jemand erklären, was der Schwachsinn soll?

So viel zur Konsistenz der WIN-API.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#2
  Alt 25. Apr 2003, 15:05
Nach Rücksprache mit Assarbad hier jetzt die optimierte Version. Damit umgeht man auch das Problem, welches Microsoft gerade zu provoziert:
Delphi-Quellcode:
procedure TWinInfo.GetCompName;
var
  buffer : array[0..MAX_PATH] of Char;
  Size: DWORD;
begin
  Size := sizeof(buffer);
  GetComputerName(buffer, Size);
  SetString(FComputerName, buffer, lstrlen(buffer));
end;
GetUserName eben so.
Michael
Ein Teil meines Codes würde euch verunsichern.
  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 12:20 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