Der Grund dafür ist, dass ich kürzlich das C-Modul von Nodejs geschrieben und es dann auf der JS-Seite aufgerufen habe. Die Netzwerkkommunikation ist natürlich untrennbar mit SSL verbunden und muss daher mit der Openssl-Bibliothek verknüpft werden.
Unsere ursprüngliche Erwartung war, dass Benutzer die Openssl-Laufzeitbibliothek installieren müssen und dann unser C-Modul dynamisch mit der Openssl-Laufzeitbibliothek verknüpft wird, damit es ausgeführt werden kann.
Zuerst sah alles gut aus, bis wir feststellten, dass diese OpenSSL-Funktion nicht funktioniert:
PKCS7_sign()
PKCS7_sign ( )
Wir haben gefunden:
Wenn unser C-Modul dynamisch mit der Openssl-Bibliothek verknüpft ist, tritt beim Kompilieren kein Problem auf. Beim Ausführen wird jedoch ein Fehler angezeigt: Das PKCS7_sign-Symbol wurde nicht gefunden.
Wenn unser C-Modul statisch mit der Openssl-Bibliothek verknüpft ist, tritt beim Kompilieren kein Problem auf, aber beim Ausführen hat der Ort, an dem diese Funktion aufgerufen wird, keine Auswirkung und der Rückgabewert dieser Funktion ist 0. Laut Dokumentation ist Es tritt ein Fehler auf, aber der Fehler wird mit der Openssl-Funktion ERR_get_error abgerufen. Der Code ist ebenfalls 0. Dies bedeutet, dass kein Fehlercode vorhanden ist.
Das trifft auf Linux zu, aber was ist mit dem Mac? Ich habe es auf dem Mac ausprobiert und festgestellt, dass es kein Problem mit dem Mac gibt. Ich dachte also, das könnte ein Fehler in Nodejs sein und habe einen Fehler gemeldet: https://github.com/joyent/node/issues/8026][1]
Gleichzeitig habe ich bei Google nach Schlüsselwörtern gesucht, die NodeJS ähneln und auf OpenSSL verlinken.
Ich habe mehrere Artikel wie diesen gefunden:
https://github.com/TooTallNate/node-gyp/wiki/Linking-to-OpenSSL
https://github.com/joyent/node/issues/3915
https://github.com/robhawkes/node-extension/issues/1
Bei der Suche haben wir herausgefunden, dass Nodejs selbst auch die Openssl-Bibliothek verwendet. Es wird spekuliert, dass das eigene Kryptomodul von Nodejs auch mithilfe der Openssl-Bibliothek implementiert ist Quellcode.
Der gutaussehende Kerl, der den ersten Artikel oben geschrieben hat: https://github.com/TooTallNate/node-gyp/wiki/Linking-to-OpenSSL ist ein Nodejs-Entwickler.
Grundlegende Schlussfolgerung:
Nodejs verwendet Openssl selbst
Vor Nodejs 0.6 war Nodejs dynamisch mit der Openssl-Bibliothek verknüpft. Spätere Versionen waren statisch verknüpft.
Zu diesem Zeitpunkt stellte ich fest, dass Node bereits auf meinen Fehler reagiert hatte: https://github.com/joyent/node/issues/8026
Der von Node erläuterte Grund:
Nachdem Node sich selbst kompiliert hatte, wurden die nicht verwendeten Symbole gelöscht, sodass wir den Fehler beheben und alle Symbole beibehalten konnten. Dies führte dazu, dass die Größe von Node größer wurde.
Danke Node für die schnelle Antwort, ich muss Nodes Aktivität bewundern.