Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon (https://www.delphipraxis.net/206176-getprocaddress-liefert-kein-ergebnis-unter-win64-unter-win32-schon.html)

Bbommel 26. Nov 2020 18:03

GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Hi zusammen,

ich komme nicht mehr weiter und brauche mal Tipps von euch. Direkt vorweg: "ja, du musst ja auch die 64-Bit-DLL nehmen, wenn du für 64-Bit kompilierst!" werden vielleicht einige direkt zurecht antworten wollen. Ja, habe ich. Ganz so einfach ist es leider nicht. Geht noch nicht mal um meinen eigenen Code, sondern um eine Bibliothek, die ich nutzen möchte. Aber der Reihe nach:

Wenn man sich mit "modernen" Anmeldeverfahren im Netz rumschlägt, dann stolpert man irgendwann über OAuth2 und die "Access Token" und "Identity Token", die man da so bekommt. Meistens liegen diese Token in Form eines "JSON Web Tokens" vor, welche diverse Informationen über die Anmeldung enthalten und schließlich auch mit einem Zertifikat signiert sind, mit dem man die Echtheit prüfen kann und soll. Damit man nicht bei Null anfangen muss, wenn man so ein Token auswerten und prüfen will, haben andere zum Glück schon vorgearbeitet, in dem Fall gibt es u.a. die Delphi JOSE and JWT Library von Paolo Rossi. Hier ist vor allem auch die ganze Zertifikatsprüfung mit eingebaut und die basiert zum Teil wiederum auf OpenSSL.

Und hier kommt es nun zu meinem Problem. Folgender Code aus der Unit JOSE.Signing.RSA von Paolo:

Delphi-Quellcode:
unit JOSE.Signing.RSA;

interface

uses
  [...]IdSSLOpenSSLHeaders,
  [...]

class procedure TRSA.LoadOpenSSL;
begin
  if not IdSSLOpenSSLHeaders.Load then
    raise Exception.Create('[RSA] Unable to load OpenSSL libraries');

  if @EVP_DigestVerifyInit = nil then
    raise Exception.Create('[RSA] Please, use OpenSSL 1.0.0. or newer!');

  if GetCryptLibHandle <> 0 then
  begin
    // *** Die folgende Zeile macht nicht, was sie soll! ***
    _PEM_read_bio_RSA_PUBKEY := GetProcAddress(GetCryptLibHandle, 'PEM_read_bio_RSA_PUBKEY');
    if @_PEM_read_bio_RSA_PUBKEY = nil then
      raise Exception.Create('[RSA] Unable to get proc address for "PEM_read_bio_RSA_PUBKEY"');

    [...]
  end;
end;
Hier soll also
Delphi-Quellcode:
GetProcAddress(GetCryptLibHandle, 'PEM_read_bio_RSA_PUBKEY')
in der libeay32.dll die Funktion PEM_read_bio_RSA_PUBKEY finden. Die Funktion
Delphi-Quellcode:
GetCryptoLibHandle
kommt aus der Indy-Unit IdSSLOpenSSLHeaders und liefert das Handle auf die libeay32.dll. Unter Win32 funktioniert das auch alles ganz wunderbar. Unter Win64 bekomme ich immer ein NIL von der Funktion.

Mit einem "DLL Export Viewer" habe ich gesehen, dass die gesuchte Funktion in der DLL auch tatsächlich existiert. Mit dem ProcessMonitor habe ich geprüft, dass auch tatsächlich die richtige, 64 bittige Version von libeay32.dll geladen wird. Wird sie ohnehin schon vorher, weil das ganze in einer Web Broker-Anwendung läuft, die auch auf OpenSSL zugreift. Da kann man beim Debuggen dann auch sehen, dass die ganzen Funktionen auch unter Win64 in der dll problemlos gefunden werden, wenn man sich die Funktion "Load" in der IdSSLOpenSSLHeaders anguckt und da einen Breakpoint setzt. Nur oben klappt es nicht.

Ich hab auch schon mal
Delphi-Quellcode:
@_PEM_read_bio_RSA_PUBKEY := GetProcAddress(GetCryptLibHandle, PChar('PEM_read_bio_RSA_PUBKEY'));

probiert, aber das brachte keinen Unterschied.

Hat irgendwer irgendeine Idee?

(Zur Info: hab das auch in einem Issue auf Github gepostet, weil dort schon jemand ein ähnliches Problem mit Mac32/Mac64 hatte)

venice2 26. Nov 2020 18:25

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Ich hab auch schon mal
Delphi-Quellcode:
@_PEM_read_bio_RSA_PUBKEY := GetProcAddress(GetCryptLibHandle, PChar('PEM_read_bio_RSA_PUBKEY'));

definition in 64Bit..

Delphi-Quellcode:
function GetProcAddress(hModule: HMODULE; lpProcName: LPCSTR): FARPROC; external kernel32 name 'GetProcAddress';
function GetProcAddress(hModule: HMODULE; lpProcName: LPCWSTR): FARPROC;
begin
  if ULONG_PTR(lpProcName) shr 16 = 0 then // IS_INTRESOURCE
    Result := GetProcAddress(hModule, LPCSTR(lpProcName))
  else
    Result := GetProcAddress(hModule, LPCSTR(TMarshal.AsAnsi(lpProcName)));
end;
Aber keine Ahnung ob dir das hilft.

Habe da einiges recherchiert.
HModule <> THandle
Int <> IntPtr wenn die DLL geladen wird.

Viele haben damit ein Problem.
Bei Google suchen GetProcAddress 64bit

himitsu 26. Nov 2020 19:35

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Und natürlich kann man auch mal schauen, ob es auch einen Export mit diesem Namen in der 64-Bit-DLL gibt.
https://www.nirsoft.net/utils/dll_export_viewer.html

venice2 26. Nov 2020 19:48

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von himitsu (Beitrag 1478024)
Und natürlich kann man auch mal schauen, ob es auch einen Export mit diesem Namen in der 64-Bit-DLL gibt.
https://www.nirsoft.net/utils/dll_export_viewer.html

Zitat:

Mit einem "DLL Export Viewer" habe ich gesehen, dass die gesuchte Funktion in der DLL auch tatsächlich existiert.
Hat er ja schon.

Aber ich finde den Key definitiv nicht!
Zumindest nicht in der DLL die ich auf dem System habe.

Der schöne Günther 26. Nov 2020 19:57

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von venice2 (Beitrag 1478023)
Habe da einiges recherchiert.
HModule <> THandle

Ganz sicher?

Windows SDK:
Code:
typedef PVOID HANDLE;
typedef HANDLE HINSTANCE;
typedef HINSTANCE HMODULE;
Die Delphi RTL ebenso:
Delphi-Quellcode:
  THandle = NativeUInt;
  HINST = THandle;             { HINSTANCE from widnef.h }
  HMODULE = HINST;             { from windef.h }

venice2 26. Nov 2020 20:02

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1478026)
Zitat:

Zitat von venice2 (Beitrag 1478023)
Habe da einiges recherchiert.
HModule <> THandle

Ganz sicher?

Windows SDK:
Code:
typedef PVOID HANDLE;
typedef HANDLE HINSTANCE;
typedef HINSTANCE HMODULE;
Die Delphi RTL ebenso:
Delphi-Quellcode:
  THandle = NativeUInt;
  HINST = THandle;             { HINSTANCE from widnef.h }
  HMODULE = HINST;             { from windef.h }

Es geht hier um 64Bit und 32Bit.
Nein aber so wie ich gelesen (Recherchiert) habe ist Cardinal 64Bit und THandle 32 oder?
http://codeverge.com/embarcadero.del...hi-get/1071384

himitsu 26. Nov 2020 20:03

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von venice2 (Beitrag 1478025)
Aber ich finde den Key definitiv nicht!

Ich seh ihn auf dem Bild auch nicht. :angle2:

venice2 26. Nov 2020 20:18

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von himitsu (Beitrag 1478028)
Zitat:

Zitat von venice2 (Beitrag 1478025)
Aber ich finde den Key definitiv nicht!

Ich seh ihn auf dem Bild auch nicht. :angle2:

Hmmm. nur den hier! PEM_read_bio_RSAPUBKEY instead of PEM_read_bio_RSA_PUBKEY
Keine Ahnung wie viele DLL's es davon gibt.

Der schöne Günther 26. Nov 2020 20:44

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Zitat:

Zitat von venice2 (Beitrag 1478027)
Es geht hier um 64Bit und 32Bit.
Nein aber so wie ich gelesen (Recherchiert) habe ist Cardinal 64Bit und THandle 32 oder?

Am besten direkt an die Doku halten, da ist das klar definiert:
http://docwiki.embarcadero.com/Libra...ystem.Cardinal
Zitat:

The size of Cardinal is 32 bits across all 64-bit and 32-bit platforms.
http://docwiki.embarcadero.com/Libra...tem.NativeUInt
Zitat:

The size of NativeUInt is equivalent to the size of the pointer on the current platform.
Auch wenn ich nicht weiß was "Cardinal" damit jetzt zu tun hat.
Delphi-Quellcode:
HMODULE = HINST = THandle
, egal wieviel Bit.

Bbommel 26. Nov 2020 20:51

AW: GetProcAddress liefert kein Ergebnis unter Win64, unter Win32 schon
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo zusammen,

Danke für euer erstes Feedback.

dass ich das schon geprüft habe, dass die Funktion auch wirklich vorhanden ist, hatte ich ja schon im Eingangspost geschrieben. Die Funktion ist in der DLL vorhanden (und auch in älteren Versionen der DLL). Also, wenn ich die OpenSSL-Doku richtig verstanden habe, müsste das zumindest in der Version 1.0.2 dabei sein.

Auszug aus dem DLL Export Viewer als Bildchen im Anhang.

Vielleicht gibt es ja tatsächlich irgendwelche Eigenarten bzgl. HModule <> THandle oder irgendwelcher anderer Typen bei der Funktion unter Win64. Ich versuche morgen mal mit frischem Kopf ein Demo-Projekt zu basteln.


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:07 Uhr.
Seite 1 von 2  1 2      

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