AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) ShellExecute liefert ERROR_ACCESS_DENIED
Thema durchsuchen
Ansicht
Themen-Optionen

ShellExecute liefert ERROR_ACCESS_DENIED

Ein Thema von Amateurprofi · begonnen am 23. Dez 2017 · letzter Beitrag vom 17. Jan 2018
Antwort Antwort
Seite 3 von 3     123   
HolgerX

Registriert seit: 10. Apr 2006
Ort: Leverkusen
969 Beiträge
 
Delphi 6 Professional
 
#21

AW: ShellExecute liefert ERROR_ACCESS_DENIED

  Alt 15. Jan 2018, 18:35
Hmm..

Da bei Delphi 7 PChar = PAnsiChar ist, kannst Du auch eigendlich konsequent immer PAnsiChar verwenden.
Jedoch dann am Besten auch ShellExecuteA und die Strings sollte dann fix AnsiString sein.

Alternativ konsequent PWideChar in Verbindung mit ShellExecuteW und WideString.

Dann ist es Type-Konform, egal welche Delphi Version.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ShellExecute liefert ERROR_ACCESS_DENIED

  Alt 16. Jan 2018, 10:49
Eine nutzbare Funktion mit abgelaufenem Code neu zu verbreiten ist nicht wirklich ideal.
Am Ende kommt noch wer auf die Idee und baut es in ein neues Programm ein.


Wie gesagt, an der Stelle ist garkein IFDEF nötig.

ReadFile liefert OEM, also ANSI,
OemToChar will ANSI rein bekommen,
also braucht der Buffer immer nur ANSI zu sein und wird somit auch explizit als ANSI deklariert. (AnsiChar/PAnsiChar/AnsiString)



Da gibt es bei deinem Trainer schlimmere Problemstellen, wenn man mit Unicode kompilieren würde (ab Delphi 2009)
und Einiges (FixStr) ist in jeder Delphiversion potentiell gefährlich.

Hier Function StatusText ( StatusID : myStatusIDs ) : pChar; stdcall; klappt das mit dem Result, da es auf Konstanten zeigt, die bestehen bleiben.

Bei Function FixStr ( Input : PChar ) : PChar; stdcall; zeigt Result auf eine temporäre Variable, die beim Verlassen der Funktion freigegeben wird.
Wird der Speicher zwischenzeitlich mit irgendwas überschrieben, dann knallt es womöglich.
War die Variable der letzte genutzte Teil des Speicherblocks, dann wird der freigegeben und es knallt.
Mit etwas Glück passiert nichts und es wird anschließend auf den noch nicht freigegebenen/überschriebenen Speicherbereich zugegriffen.

MessageBox(Handle, PAnsiChar(... : Wie schon gesagt, muß alles zusammenpassen.
String > PChar > MessageBox
AnsiString > PAnsiChar > MessageBoxA
WideString/UnicodeString > PWideChar > MessageBoxW

Mein Tipp wäre hier einfach immer nur mit String/AnsiString/WideString/... zu arbeiten, vorallem bezütlich String-Verarbeitung und Speichermanagement (speichern und weitergeben der Strings)
und nur bei übergabe an die WinAPI nach PChar zu casten.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (16. Jan 2018 um 11:09 Uhr)
  Mit Zitat antworten Zitat
Fukiszo
(Gast)

n/a Beiträge
 
#23

AW: ShellExecute liefert ERROR_ACCESS_DENIED

  Alt 16. Jan 2018, 22:06
beim debuggen der shellexecute funktion ist mir folgendes aufgefallen,
wenn die datei die man mit shellexecute ausführen will,
die aber "locked" ist, wie zum beispiel "PageFile.sys"
dann gibt es leider auch den ERROR_ACCESS_DENIED.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

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

AW: ShellExecute liefert ERROR_ACCESS_DENIED

  Alt 17. Jan 2018, 00:00
Das ist doch in Ordnung. Warum leider?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Fukiszo
(Gast)

n/a Beiträge
 
#25

AW: ShellExecute liefert ERROR_ACCESS_DENIED

  Alt 17. Jan 2018, 01:25
mit leider mein ich die plumpe rückmeldung "Zugriff verweigert."
wenn du zum beispiel eine datei ausführen willst,
die physikalisch zwar vorhanden, im explorer auch angezeigt wird,
aber eine execution unmöglich ist mit obriger rückmeldung,
weisst du ja eigentlich immernoch nicht wieso weshalb warum.
stünde da ein ERROR_FILE_LOCKED zur verfügung,
hät man das schneller unter kontrolle.
ich hab zwar eine "IsFileInUse" funktion,
die fängt aber leider nicht solche locked files ab.
die sagt logischerweise, klar, file is in use, weil's ja locked ist und irgendein process XYZ der die datei offen hat.
ich such mal im DP ob es eine möglichkeit gibt den status zu prüfen (locked/unlocked)...
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 3     123   


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 22:39 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