AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi IOResult und FileExists bei UAC unter Vista fehlerhaft?
Thema durchsuchen
Ansicht
Themen-Optionen

IOResult und FileExists bei UAC unter Vista fehlerhaft?

Ein Thema von amigage · begonnen am 5. Apr 2007 · letzter Beitrag vom 5. Apr 2007
Antwort Antwort
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
274 Beiträge
 
Delphi 12 Athens
 
#1

IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 09:44
Hallo,

Ich hoffe, mir kann jemand helfen.

Mein Problem ist folgendes. Ich suche nach einer Möglichkeit, herauszufinden, ob in einen angegebenen Ordner geschrieben werden kann. Also versuche ich per AssignFile eine Datei in dem Ordner anzulegen.

Delphi-Quellcode:
function TestWriteSuccess(Ordner: String) : Boolean;
var
  F : TextFile;
  tmp : integer;
  FileAvail : Boolean;
const
  Dateiname = 'test.tmp';
begin

  result := true;
  FileAvail := true;

  AssignFile(F, Ordner + Dateiname);
{$I-}
  ReWrite(F);
{$I+}
  tmp := ioresult;
  if tmp = 0 then
  begin // erfolgreich
// Showmessage('Erfolgreich! ioresult='+inttostr(tmp));
    Result := true;
    CloseFile(F);
    If FileExists(Ordner + Dateiname) then
    begin
       showmessage('Datei ' + Ordner + Dateiname + ' wurde erfolgreich angelegt und gefunden!');
       DeleteFile(Ordner + Dateiname)
    end
    else
      FileAvail := false;
  end;

  If ((tmp <> 0) or (FileAvail = false)) then
  begin // nicht erfolgreich
// showmessage('Nicht erfolgreich! ioresult='+inttostr(tmp));
    Showmessage('In den angegebenen Ordner "' + Ordner + '" kann die Software aufgrund eingeschränkter Zugriffsrechte nicht schreiben.');
    Result := false;
  end;
end;
Unter Windows XP wird mir das richtige IOResult der Rewrite() Funktion zurückgegeben, wenn ich z.B. versuche auf eine nicht beschreibbare DVD zu schreiben. Dies funktioniert auch unter Vista. Fast...

Versuche ich nämlich in den Programmordner zu schreiben, der mit eingeschaltetem UAC für Programme ohne Adminrechte tabu ist, funktioniert die Routine nicht. Ich erhalte IOResult = 0, obwohl mir das Schreiben verwährt wird. Also dachte ich mir, teste ich mal mit FileExists(), ob die Datei auch wirklich vorhanden ist. Die Meldung wird eingeblendet, aber wenn ich bei eingeblendete Meldung in den Ordner schaue, ist keine Datei geschrieben worden.

Wie hängt das zusammen? Wie kann ich es trotzdem unter Vista kontrollieren. Ich will ja den Anwendern nicht die Auswahl "verbotener" Ordner erlauben....

Danke für jeden Hinweis.
Amigage
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 10:04
Die Funktion FileExists aus Unit SysUtils war schon immer etwas mangelhaft.
Grund:
FileExists stützt sich auf FileAge ab. So kann es passieren, dass eine vorhandene Datei
mit defektem Datums-/Zeiteintrag als nicht vorhanden gemeldet wird.

Hat dir eigentlich noch niemand gesagt, dass die Funktionen
AssignFile, ReWrite, CloseFile, Write, Read, ... und der Datentyp File (und alle Verwandten)
steinalte Überbleibsel aus den Anfangstagen von Pascal sind ?

Stattdessen sollte TFileStream verwendet werden.
Für deinen Zweck (herauszufinden, ob in einen angegebenen Ordner geschrieben werden kann)
sollte man noch näher an die Windows API herangehen:

Delphi-Quellcode:
function IsPathWriteable(const path:string):Boolean;
var
   filename : string;
   hnd : THandle;
begin
   filename := IncludeTrailingBackslash(path)+'.$$$'; // temporary filename
   DeleteFile(PChar(filename));

   hnd := CreateFile(PChar(filename),GENERIC_WRITE, 0, nil, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL,
      0);

   if hnd <> INVALID_HANDLE_VALUE then
   begin
      CloseHandle(hnd);
      DeleteFile(PChar(filename));
      Result := True;
   end
   else
      Result := False;
end;
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 10:17
Zitat von amigage:
Versuche ich nämlich in den Programmordner zu schreiben, der mit eingeschaltetem UAC für Programme ohne Adminrechte tabu ist, funktioniert die Routine nicht. Ich erhalte IOResult = 0, obwohl mir das Schreiben verwährt wird. Also dachte ich mir, teste ich mal mit FileExists(), ob die Datei auch wirklich vorhanden ist. Die Meldung wird eingeblendet, aber wenn ich bei eingeblendete Meldung in den Ordner schaue, ist keine Datei geschrieben worden.

Wie hängt das zusammen? Wie kann ich es trotzdem unter Vista kontrollieren. Ich will ja den Anwendern nicht die Auswahl "verbotener" Ordner erlauben....
Das nächste Opfer von UAC
Deine Zugriff auf dies "verbotene" Ordner (Windows, Programme, ...) werden "virtualisiert". D.h. dein Programm bekommt eine virtuelles Verzeichnis untergeschoben wo es schreiben darf. Im Taskmanager siehst du sehr einfach mit der neuen Spalte "Virtualisierung" welche Programm damit arbeiten und welche nicht.

Lösung: Angepaßtes XP-Manifest in dem du definierst das du nicht Virtualisiert werden willst.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

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

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 10:21
Zitat von amigage:
Wie hängt das zusammen? Wie kann ich es trotzdem unter Vista kontrollieren. Ich will ja den Anwendern nicht die Auswahl "verbotener" Ordner erlauben....
Eigentlich dachte ich, dass sich das mittlerweile rumgesprochen hätte. Vista leitet in solchen Fällen die Schreibaktionen auf einen Ordner im Profilverzeichnis des Benutzers um.

@shmia: Dein Code wird auch das gleiche Schicksal erleiden.

Perobier mal diesen Code von Nico: http://www.michael-puff.de/Developer...ileAccess.html
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
274 Beiträge
 
Delphi 12 Athens
 
#5

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 10:50
Erst einmal danke für die Hilfe.
Jetzt brauche ich zumindest nicht mehr in meinem Code nach Fehlern suchen

Zitat von shmia:
Hat dir eigentlich noch niemand gesagt, dass die Funktionen
AssignFile, ReWrite, CloseFile, Write, Read, ... und der Datentyp File (und alle Verwandten)
steinalte Überbleibsel aus den Anfangstagen von Pascal sind ?
Das verwende ich auch sehr ungern. Aber für einen Test habe ich hier im Forum das Grundgerüst gefunden und nur ein wenig erweitert. Warum erst umstricken, wenn es - wie in diesem Fall - sowieso nicht den gewünschten Erfolg bringt

@Luckie: Ich werde mal den Code von Nico probieren. Danke für den Tipp!
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
274 Beiträge
 
Delphi 12 Athens
 
#6

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 11:58
Hhhmmmm, so ganz scheint der Code von Nico mein Problem nicht zu lösen.
Ich will ja testen, ob eine Datei in ein Verzeichnis geschrieben werden kann. Demzufolge habe ich shmias Code mit Nicos Code kombiniert.

Delphi-Quellcode:
function TMainDlg.CheckWriteSuccess(Ordner: String) : Boolean;
var
   filename : string;
   hnd : THandle;
const
  TmpDateiname = 'mytmp.$$$';
begin
  filename := IncludeTrailingBackslash(ordner) + TmpDateiname;
  DeleteFile(PChar(filename));

  hnd := CreateFile(PChar(filename),GENERIC_WRITE, 0, nil, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
  if hnd <> INVALID_HANDLE_VALUE then
  begin
    CloseHandle(hnd);

    Result := CheckAccessToFile(GENERIC_WRITE, filename); // <--

    DeleteFile(PChar(filename));
  end
  else
    Result := False;

  If Result = false then
    Showmessage('In den angegebenen Ordner "' + Ordner + '" kann die Software aufgrund eingeschränkter Zugriffsrechte nicht schreiben.');
end;

procedure TMainDlg.SaveDialogCanClose(Sender: TObject;
  var CanClose: Boolean);
begin
  CanClose := CheckWriteSuccess(ExtractFilePath(SaveDialog.Filename));
end;
Wenn also im SaveDialog eine Datei angegeben wird, "schreibt shmia" die Testdatei und "Nico schaut", ob die vorhanden ist. Das will bei mir nicht klappen. CheckAccessToFile() gibt true zurück, obwohl die Datei nicht vorhanden ist... Oder habe ich jetzt einen Denkfehler?
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

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

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 12:05
Du kannst Nicos Code auch ein Verzeichnis übergeben. Du musst nicht erst eine Datei erstellen. Und hättest du die vorherigen Postings gelsen, wüsstest du, dass das Erstellen einer Datei gar nichts bedeutet, wenn die Virtualisierung aktiviert ist.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
274 Beiträge
 
Delphi 12 Athens
 
#8

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 12:31
Das bedeutet also, dass es keine Möglichkeit gibt, dies zu überwachen und man
sich auf Anwenderanfragen einstellen muss, die dann nachfragen, warum dass und
das nicht funktioniert

Trotzdem danke für die Hinweise...

Oder kann man die Virtualisierung für das eigene Programm abstellen?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 12:36
Zitat von Bernhard Geyer:
Lösung: Angepaßtes XP-Manifest in dem du definierst das du nicht Virtualisiert werden willst.
$2B or not $2B
  Mit Zitat antworten Zitat
amigage

Registriert seit: 11. Nov 2005
Ort: Leipzig
274 Beiträge
 
Delphi 12 Athens
 
#10

Re: IOResult und FileExists bei UAC unter Vista fehlerhaft?

  Alt 5. Apr 2007, 12:52
Sorry! Wer lesen kann, ist klar im Vorteil
  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 03:17 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