SSL-Webserver mit Express, Unterstützt HTTP/2
npm i @sumor/ssl-server --save
Erfordert Node.JS-Version 16.x oder höher
Da dieses Paket in ES-Modul geschrieben ist, ändern Sie bitte den folgenden Code in Ihrer package.json-Datei:
{
"type": "module"
}
import createApp from '@sumor/ssl-server'
const app = createApp()
// standardmäßig auf Port 443 hören und Port 80 auf HTTPS 443 umleiten
await app.listen()
Fügen Sie bitte SSL-Dateien in den Stammordner ssl mit den folgenden Namen hinzu:
domain.crtdomain.keyca.crt (Optional, wird an die Zertifikatskette angehängt)Falls nicht gefunden, wird der Server ein selbstsigniertes Zertifikat generieren.
Bei Änderung der SSL-Dateien wird automatisch neu geladen.
Es unterstützt alle Funktionen von express, der einzige Unterschied liegt in den Methoden listen und close. Bitte beachten Sie das folgende Beispiel für weitere Details.
import createApp from '@sumor/ssl-server'
const app = createApp()
import bodyParser from 'body-parser'
// Sie können beliebige Express-Middleware hinzufügen
app.use(bodyParser.json())
// Routen hinzufügen
app.get('/', (req, res) => {
res.send('Hello World!')
})
// listen ist eine asynchrone Funktion
await app.listen()
import createApp from '@sumor/ssl-server'
const app = createApp()
// listen ist eine asynchrone Funktion
await app.listen()
// close ist eine asynchrone Funktion
await app.close()
import createApp from '@sumor/ssl-server'
const app = createApp()
// listen ist eine asynchrone Funktion
await app.listen(8443, 8080)
console.log(`Server läuft auf https://localhost:8443/`)
console.log(`Umleitungs-Server läuft auf http://localhost:8080/`)