|
Das deutsche QBasic- und FreeBASIC-Forum Für euch erreichbar unter qb-forum.de, fb-forum.de und freebasic-forum.de!
|
Vorheriges Thema anzeigen :: Nächstes Thema anzeigen |
Autor |
Nachricht |
dreael Administrator
Anmeldungsdatum: 10.09.2004 Beiträge: 2507 Wohnort: Hofen SH (Schweiz)
|
Verfasst am: 13.02.2014, 16:52 Titel: Verwendung von wincrypt.bi |
|
|
Inzwischen einmal selber ein etwas komplizierteres Mini-Projekt (eigentlich nur einmal ein Demo-Beispiel) für die Win32-API-Profis begonnen: Zugriff auf den Smartcard-Leser sowie SuisseID via Windows-Crypto-API. Entwurf:
http://beilagen.dreael.ch/QB/SuisseIDTest.bas
Problem: Bin bis zum Punkt gekommen, wo der Compiler ein .o bildet, d.h. aktuelle Fehler:
FbEdit-Ausgabe hat Folgendes geschrieben: | C:\Program Files (x86)\FreeBASIC\fbc -s gui "SuisseIDTest.bas"
SuisseIDTest.bas(17) warning 1(1): Passing scalar as pointer, at parameter 1 of CERTOPENSTORE()
SuisseIDTest.o:fake:(.text+0x70): undefined reference to `CertOpenStore@20'
SuisseIDTest.o:fake:(.text+0xa7): undefined reference to `CertCloseStore@8'
Build error(s) |
Problem 1: Unter
http://msdn.microsoft.com/en-us/library/windows/desktop/aa376559%28v=vs.85%29.aspx
ist dieser API-Aufruf beschrieben, nur bin ich noch nicht ganz schlau geworden, wie die Compilerwarnung in diesem konkreten Fall vermieden werden kann.
Problem 2: Offensichtlich benötigt der Linker noch Teile, um eine .exe daraus erstellen zu können. Folgende Datei bereits gesehen:
%programFiles%\FreeBasic\FreeBASIC\lib\win32\libcrypt32.dll.a
=> Wie teile ich dem Compiler bzw. genauer den FbEdit-Projektoptionen mit, diese Bibliothek miteinzubinden?
Endziel: Kleine Demo, welches die in den Internetoptionen unter "Inhalte", "Zertifikate" bei "Eigene Zertifikate" enthaltenen Zertifikate anzeigt, eines davon auswählen lässt. Anschliessend mit normalem FreeBasic-Rnd() ein Hash-Wert in einem Byte-Array erzeugen, diesen mit dem privaten Schlüssel signieren (=> in meinem Fall müsste dann der Kartenleser anspringen), ausgeben und mit dem öffentlichen Schlüssel im Zertifikat wieder zurückrechnen => müsste dann wieder identisch sein.
Fürs erste reicht es mir einmal aus, wenn das Beispiel einen CertOpenStore() und CertCloseStore() mit Eurer Hilfe machen kann. _________________ Teste die PC-Sicherheit mit www.sec-check.net |
|
Nach oben |
|
|
Jojo alter Rang
Anmeldungsdatum: 12.02.2005 Beiträge: 9736 Wohnort: Neben der Festplatte
|
Verfasst am: 13.02.2014, 18:11 Titel: Re: Verwendung von wincrypt.bi |
|
|
Zum ersten Problem: In der Original-wincrypt.h finden sich folgende Defines:
Code: | #define CERT_STORE_PROV_SYSTEM_A ((LPCSTR) 9)
#define CERT_STORE_PROV_SYSTEM_W ((LPCSTR) 10)
#define CERT_STORE_PROV_SYSTEM CERT_STORE_PROV_SYSTEM_W
|
In der wincrypt.bi fehlen die passenden Casts nach LPCSTR (Pointer auf konstanten String):
Code: | #define CERT_STORE_PROV_SYSTEM 10 |
Sauber wäre natürlich, die Definition anzupassen, aber momentan wirst du dich damit begnügen müssen, den Cast selbst durchzuführen. _________________ » Die Mathematik wurde geschaffen, um Probleme zu lösen, die es nicht gäbe, wenn die Mathematik nicht erschaffen worden wäre.
|
|
Nach oben |
|
|
|
|
Du kannst keine Beiträge in dieses Forum schreiben. Du kannst auf Beiträge in diesem Forum nicht antworten. Du kannst deine Beiträge in diesem Forum nicht bearbeiten. Du kannst deine Beiträge in diesem Forum nicht löschen. Du kannst an Umfragen in diesem Forum nicht mitmachen.
|
|