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をインストールして自動起動を設定する方法

推薦する

nginx で複数の仮想ホストを設定する方法の例

nginx で仮想ホスト vhost を設定すると非常に便利です。 nginx設定ファイルnginx...

Linux centos7 に phpMyAdmin をインストールするチュートリアル

yum install httpd php mariadb-server –yランプの動作環境を設定...

表のセル間隔とセルパディングの違いの詳細な説明

テーブルとは何ですか?セルセルで構成されています。表では、<td> の数は、<tr...

Windows に MySQL をインストールする方法のグラフィック チュートリアル

概要: この記事では主に、Windows 環境に MySQL をインストールする方法について説明しま...

建国記念日が近づいています。JS を使用して、建国記念日風のアバターを生成する小さなツールを実装します。実装プロセスの詳細な説明

目次1. ページレイアウト2. 画像のアップロードと表示3. キャンバスを初期化する4. テンプレー...

SQL で行の最大値または最小値を取得する方法

元データと対象データSQL文を実装する(最大) 選択 店、 月、 最大(dz,fz,sp) が最大値...

仮想マシンの複製に関するVirtual Boxチュートリアル図

VMに慣れた後、BOXに切り替えるのは少し異なります。たとえば、コピーネットワークカードを2枚使って...

ツールキット: Bootstrap よりも強力なフロントエンド フレームワーク

注: 現在、最も人気のフロントエンド フレームワークは Bootstrap と Foundation...

Win10 への MySQL 5.7 のインストール MSI 版のチュートリアル(画像とテキスト付き)

主にインストール後に my.ini ファイルを確認するために、msi 形式でインストールしました。フ...

サーバーの購入と初期構築方法

しばらくサーバーいじってなかったけど、やることがなくなったのでモバイルワークスに行って海外サーバーを...

ウェブデザイナー職の面接でよくある質問と回答

1. ASP.NET Web アプリケーションのテンプレートとは何ですか? それらの違いは何ですか?...

Nginx の高同時実行最適化の実践

1. チューニングの必要性​ 私は、どのように書けばいいのか本当に分からないので、共有するために最適...

.NETCore Dockerはコンテナ化とプライベートイメージリポジトリ管理を実装します

1. Dockerの紹介Docker は Linux オペレーティングシステムの一部の機能をベースに...

HTML で入力テキスト入力キャッシュのクリアを禁止する 2 つの方法

ほとんどのブラウザはデフォルトで入力値をキャッシュし、ctl+F5 を使用して強制的に更新することに...

Windows プラットフォームでの MySQL のインストールと設定方法と注意事項

2.1、msiインストールパッケージ2.1.1、インストール特に重要なのは、インストール前に、元の ...