NestJSJWT戦略にはシークレットまたはキーが必要です

ロブベイリー

NestJSノードアプリケーションで、Passportを使用してJWT認証を設定しました(https://docs.nestjs.com/techniques/authenticationに従って)が、ビルドを使用して取得された環境ファイルにJWTキーを保持しようとしています- ConfigServiceで。

export class JwtStrategy extends PassportStrategy(Strategy) {
  constructor(private readonly configService: ConfigService) {
    super({
      jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
      ignoreExpiration: false,
      secretOrKey: configService.get<string>('JWT_KET'),
      signOptions: { expiresIn: '60s' }
    });
  }

モジュールは次のように登録されます。

JwtModule.registerAsync({
      imports: [ConfigModule],
      useFactory: (configService: ConfigService) => {
        return {
          secret: configService.get<string>('JWT_KET')
        };
      },
      inject: [ConfigService]
    })

アプリの起動時に次のエラーが発生します。

api: [Nest] 16244   - 03/27/2020, 10:52:00   [ExceptionHandler] JwtStrategy requires a secret or key +1ms

ConfigServiceがJWTキーを提供する準備ができる前に、JWTStrategyクラスがインスタンス化されており、を呼び出すと、ストラテジー内で未定義が返されているようconfigService.get<string>('JWT_KET')です。

私はここで何が間違っているのですか?環境変数を取得する前に、ConfigServiceの準備ができていることを確認するにはどうすればよいですか?

更新:AuthModule全体は以下のとおりです。

import { AuthController } from './auth.controller';
import { AuthService } from './auth.service';
import { JwtStrategy } from './strategies/jwt.strategy';
import { LocalStrategy } from './strategies/local.strategy';
import { SharedModule } from '../shared/shared.module';
import { UsersModule } from '../users/users.module';
import { ConfigModule, ConfigService } from '@nestjs/config';
import { JwtModule } from '@nestjs/jwt';
import { Module } from '@nestjs/common';
import { PassportModule } from '@nestjs/passport';

const passportModule = PassportModule.register({ defaultStrategy: 'jwt' });
@Module({
  imports: [
    UsersModule,
    passportModule,
    JwtModule.registerAsync({
      imports: [ConfigModule],
      useFactory: async (configService: ConfigService) => {
        return {
          secret: configService.get<string>('JWT_KET')
        };
      },
      inject: [ConfigService]
    })
  ],
  providers: [ConfigService, AuthService, LocalStrategy, JwtStrategy],
  controllers: [AuthController],
  exports: [passportModule]
})
export class AuthModule {}
ジェイ・マクドニエル

私は、問題は、あなたがされていないことであることを賭けて喜んでするつもりですimportINGのConfigModuleAuthModuleし、代わりに、追加するConfigServiceproviders直接配列。これConfigModuleは、で何らかの設定を行ったConfigService場合、それはもう発生しないことを意味します。代わりに必要なものは次のようなものです。

@Module({
  imports: [
    PassportModule.register({defaultStrategy: 'jwt' }),
    UserModule,
    JwtModule.registerAsync({
      imports: [ConfigModule],
      useFactory: async (configService: ConfigService) => {
        return {
          secret: configService.get<string>('JWT_KEY')
        };
      },
      inject: [ConfigService]
    }),
    ConfigModule,
  ],
  providers: [LocalStrategy, JwtStrategy, AuthService],
  controllers: [AuthController],
  exports: [PassportStrategy],
})
export class AuthModule {}

これで、が長ければ、問題なく起動ConfigModule exports ConfigServiceするAuthModuleはずです。

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

Related 関連記事

ホットタグ

アーカイブ