Sumor Cloud のツール。
詳細なドキュメント
Expressを使用したSSL Webサーバーで、HTTP/2をサポートしています
npm i @sumor/ssl-server --save
Node.JS バージョン18.x以上が必要です
このパッケージはESモジュールで書かれているため、package.json
ファイル内で以下のコードを変更してください:
{
"type": "module"
}
import createApp from '@sumor/ssl-server'
const app = createApp()
// ポートが指定されていない場合、デフォルトでポート443でリッスンし、80をhttps 443にリダイレクトします
await app.listen()
console.log('Server running at https://localhost:443/')
SSLファイルをルートフォルダー ssl
に次の名前で追加してください:
domain.crt
domain.key
ca.crt
(オプション、証明書チェーンに追加されます)見つからない場合、サーバーは自己署名証明書を生成します。
SSLファイルが変更されると、自動的にリロードされます。
全ての express の機能をサポートしており、listen
およびclose
メソッドの違いだけがあります。詳細については以下の例を参照してください。
import createApp from '@sumor/ssl-server'
const app = createApp()
import bodyParser from 'body-parser'
// 任意のexpressミドルウェアを追加できます
app.use(bodyParser.json())
// ルートを追加
app.get('/', (req, res) => {
res.send('Hello World!')
})
// listen は非同期関数です
await app.listen()
import createApp from '@sumor/ssl-server'
const app = createApp()
// listen は非同期関数です
await app.listen()
// close は非同期関数です
await app.close()
import createApp from '@sumor/ssl-server'
const app = createApp()
// listen は非同期関数です
await app.listen(8443, 8080)
console.log(`Server is running on https://localhost:8443/`)
console.log(`Redirect server is running on http://localhost:8080/`)
import createApp from '@sumor/ssl-server'
const app = createApp()
// listen は非同期関数です
await app.listen(null, 8080)
console.log(`Redirect server is running on http://localhost:8080/`)
デフォルトでは、sslサーバーは最新のexpressのロングタームサポートバージョンを使用します。createApp
関数に渡して独自のexpressアプリを使用できます。
import createApp from '@sumor/ssl-server'
import express from 'express'
const expressApp = express()
expressApp.get('/', (req, res) => {
res.send('Hello World!')
})
const app = createApp(expressApp)
// listen は非同期関数です
await app.listen()
console.log('Server running at https://localhost:443/')