Nest.js 環境変数の設定とシリアル化の詳細な説明

Nest.js 環境変数の設定とシリアル化の詳細な説明

環境変数の設定の簡単な説明

プログラムは、環境によって異なる環境変数を必要とします。たとえば、実稼働環境、テスト環境、開発環境では、リンク アドレス、リンク ポート番号、ログイン ユーザー名、パスワード関連情報など、異なるデータベース情報が必要です。この問題を解決するには、関連する操作を実行する必要があります。

Nest での最適なアプローチは、環境固有の .env ファイルをロードする ConfigService を公開する ConfigModule を作成することです。 Nest はすぐに使える @nestjs/config を提供します。

構成

npm エコシステムには、最も単純なものを含め、関連する依存関係パッケージが多数あります。

糸を追加 dotenv-flow
糸を追加 @types/dotenv-flow -D

インストール後、main.ts で直接使用します。

'dotenv-flow' から dotenv として * をインポートします

/**
 * .env 環境をインポート * https://www.npmjs.com/package/dotenv-flow
 */
config() は、

対応する環境 .env 変数を使用することもできますが、公式に推奨されているパッケージ @nestjs/config を使用してください。

糸を追加 @nestjs/config

app.module.ts の forRoot 静的メソッドで環境変数 .env 解析を構成します。

'@nestjs/common' から { モジュール } をインポートします。
'@nestjs/config' から ConfigModule をインポートします。

@モジュール({
 インポート: [ConfigModule.forRoot()]
})
クラス AppModule をエクスポートします {}

次に、プロジェクトのルート ディレクトリに新しい .env ファイルを作成します。

データベースユーザー=
データベースパスワード=
データベース名=
データベースポート=
データベースホスト=

カスタム環境パス

.env を本番環境、テスト環境、開発環境に合わせて調整する必要がある場合は、次のように構成できます。

ConfigModule.forRoot({
 envFilePath: ['.env.development.local', '.env.development'],
})

先にソートされたものが最も優先度が高いですが、起動コマンドで環境変数を設定すると、最も優先度が高くなります。次に例を示します。

エクスポート DATABASE_USER=root && nest start

カスタム構成ファイル

複雑なプロジェクトの場合は、新しい src/config/configuration.ts を作成するなど、使用される構成可能な変数を収集する必要があります。

エクスポートデフォルト()=>({
 ポート: parseInt(process.env.PORT, 10) || 3000,
 データベース: {
  ホスト: process.env.DATABASE_HOST || 'localhost',
  ポート: parseInt(process.env.DATABASE_PORT, 10) || 3306
 }
})

次に、ConfigModule.forRoot にロードします。

'./config/configuration' から設定をインポートします

@モジュール({
 輸入: [
  ConfigModule.forRoot({
   ロード: [構成]
  })
 ]
})
クラス AppModule をエクスポートします {}

設定変数の読み取り

関連する構成変数を読み取る必要がある場合は、ConfigService を使用し、使用する *.module.ts ファイルに導入する必要があります。

@モジュール({
 インポート: [ConfigModule],
 // ...
})

関係する場所が多い場合、各モジュールをインポートするのは面倒です。上記の app.module.ts で行うことができます。

フィールドを追加します:

'./config/configuration' から設定をインポートします

@モジュール({
 輸入: [
  ConfigModule.forRoot({
   isGlobal: true、
   ロード: [構成]
  })
 ]
})
クラス AppModule をエクスポートします {}

次に、それをコンストラクターに挿入します。

'@nestjs/config' から ConfigService をインポートします。

コンストラクター(プライベートconfigService: ConfigService) {}

次のような構成変数を取得します。

const dbUser = this.configService.get<文字列>('DATABASE_USER')
const dbHost = this.configService.get<文字列>('database.host')

シリアル化

シリアル化とは、プログラムがネットワーク応答でオブジェクトを返して送信する前のプロセスを指します。提供された情報は、クライアントに送信する前に変換およびクリーンアップする必要があります。たとえば、ユーザーを照会する場合、現在のユーザー エンティティ情報は通常返されますが、その中のパスワード情報はクライアントに送信できないため、ここで何らかの変換を行う必要があります。

幸いなことに、Nest は class-transformer と呼ばれる非常に便利なパッケージを提供しています。

yarn クラストランスフォーマーを追加

たとえば、次のユーザー エンティティ情報ではパスワード情報は除外されます。

'class-transformer' から { 除外 } をインポートします

エクスポートクラスUserEntity {
 id: 番号
 firstName: 文字列;
 lastName: 文字列;

 @除外()
 パスワード: 文字列;

 コンストラクター(部分: Partial<UserEntity>) {
  オブジェクトに部分的な代入を行う。
 }
}

次に、コントローラーでクエリ ユーザー メソッドを処理します。

@UseInterceptors(クラスシリアライザーインターセプター)
@Get(':id')
findOne(@Param('id') id: 文字列): Promise<UserEntity> {
 this.userService.findOne(id) を返します。
}

最後のクエリではパスワードの表示が省略されます。

要約する

Nest.js 環境変数の設定とシリアル化に関するこの記事はこれで終わりです。Nest.js 環境変数の設定に関するその他の関連コンテンツについては、123WORDPRESS.COM で過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  MySQL における Decimal 型と Float Double 型の違い (詳細説明)

>>:  CentOS7にNginxをインストールして自動起動を設定する方法

推薦する

CSSは親要素の下の最初の子要素を選択します(:first-child)

序文最近、プロジェクトで :first-child を使用したのですが、すぐに思いつきました。これは...

Dockerイメージをパッケージ化し、リモートサーバーにプッシュしてk8sにデプロイする方法

目次1. Dockerファイル2. pom 構成3. イメージプッシュ4. k8s デプロイメント前...

MySQLデッドロックの原因と解決策

データベースは、オペレーティング システムと同様に、複数のユーザーが使用する共有リソースです。複数の...

Web Storage APIの使用に関する簡単な説明

目次1. ブラウザのローカルストレージ技術1.1、セッションストレージ1.2、ローカルストレージ2....

HTMLのインライン要素とブロックレベル要素とは何か、またそれらの違いは何ですか

以前の就職面接で面接官が尋ねた質問を覚えています。「インライン要素とは何ですか。ブロックレベル要素と...

HTMLページでよく使われるいくつかの小さなメソッド

<Head>タグに追加する<meta http-equiv="pragm...

この記事ではCSSの組み合わせセレクターの使い方を説明します

CSS 組み合わせセレクターには、単純なセレクターのさまざまな組み合わせが含まれます。 CSS3 に...

MySQL の日付と時刻関数の概要 (MySQL 5.X)

1. MySQLは現在の日付と時刻を取得する関数1.1 現在の日付 + 時刻 (日付 + 時刻) ...

MySQL でデータ復旧に binlog を使用する方法

序文最近、オンラインでデータが誤って操作されました。データベースが直接変更されたため、それを回復する...

HTML入力ボックスの最適化により、ユーザーエクスペリエンスと使いやすさが向上します。

ユーザーエクスペリエンスと使いやすさを向上させるために、入力ボックスなど、Web ページでユーザーが...

Vueコンポーネントドキュメント生成ツールライブラリのメソッド

目次.vue ファイルの解析文書情報を抽出するコンポーネント名、説明、プロパティ、メソッド、モデルを...

ウェブページでコンテンツを引用するためによく使われるHTMLタグをマスターする

長い引用には blockquote を、短い引用には q を、参考文献には cite を使用します。...

Linux でアップロードされたファイルのスケジュールされたバックアップと増分バックアップを実装する方法

導入Alibaba Cloud のような OSS ストレージ サービスを使用している場合は、サービス...

MySQL EXPLAIN ステートメントの使用例

目次1. 使用方法2. 出力結果1.id 2.選択タイプ3.表4.パーティション5.タイプ6.可能な...

mysql zipファイルのインストールチュートリアル

この記事では、参考までにMySQL zipファイルをインストールする具体的な方法を紹介します。具体的...