1

我正在为我的 NestJS 项目实施身份验证。我严格遵循了 NestJS 文档,但是当我尝试启动 API 时仍然出现错误。我似乎无法弄清楚是什么原因造成的。我尝试将其设置secretOrKey为硬编码字符串,但没有生效,然后我将其移至.env仍然无法正常工作的位置。

下面是我的模块代码和 JwtStrategy 文件。

// AuthModule
@Module({
  imports: [
    ConfigModule.forRoot(),
    UserModule,
    PassportModule.register({ defaultStrategy: 'jwt' }),
    TypeOrmModule.forFeature([Registration]),
    JwtModule.register({
      secretOrPrivateKey: process.env.JWT_SECRET_KEY,
      signOptions: { expiresIn: process.env.JWT_EXPIRES }
    }),
  ],
  controllers: [AuthController],
  providers: [AuthService, LocalStrategy, JwtStrategy],
  exports: [AuthService, LocalStrategy, JwtStrategy]
})
export class AuthModule {}
// JWTStrategy
import { Injectable, UnauthorizedException } from "@nestjs/common";
import { PassportStrategy } from "@nestjs/passport";
import { Strategy, ExtractJwt } from "passport-jwt";
import { AuthService } from "./auth.service";

@Injectable()
export class JwtStrategy extends PassportStrategy(Strategy) {
  constructor(private readonly authService: AuthService) {
    super({
      jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(),
      passReqToCallback: true,
      secretOrKey: 'test'
    })
  }

  async validate(payload: any, done: Function) {
    const user = await this.authService.validateUserToken(payload)
    if (!user) {
      return done(new UnauthorizedException(), false)
    }

    done(null, user)
  }
}

这是我从终端得到的错误

[Nest] 6876   - 05/11/2020, 10:54:31 PM   [NestFactory] Starting Nest application...
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] AppModule dependencies initialized +76ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] TypeOrmModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] PassportModule dependencies initialized +1ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] PassportModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] JwtModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] ConfigHostModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] ConfigModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] TypeOrmCoreModule dependencies initialized +121ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] TypeOrmModule dependencies initialized +1ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [InstanceLoader] TypeOrmModule dependencies initialized +0ms
[Nest] 6876   - 05/11/2020, 10:54:31 PM   [ExceptionHandler] JwtStrategy requires a secret or key +20ms
TypeError: JwtStrategy requires a secret or key
    at new JwtStrategy (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/passport-jwt/lib/strategy.js:45:15)
    at new MixinStrategy (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/passport/dist/passport/passport.strategy.js:31:13)
    at new LocalStrategy (/Users/user/Documents/code/sideline/hyperspotters-api/dist/src/auth/local.strategy.js:18:9)
    at Injector.instantiateClass (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/core/injector/injector.js:289:19)
    at callback (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/core/injector/injector.js:76:41)
    at processTicksAndRejections (internal/process/task_queues.js:97:5)
    at async Injector.resolveConstructorParams (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/core/injector/injector.js:117:24)
    at async Injector.loadInstance (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/core/injector/injector.js:80:9)
    at async Injector.loadProvider (/Users/user/Documents/code/sideline/hyperspotters-api/node_modules/@nestjs/core/injector/injector.js:37:9)
    at async Promise.all (index 4)
✨  Done in 11.99s.
4

1 回答 1

1

我在我的 local.strategy.ts 文件中发现了问题,而不是从 passport-local 导入 Strategy 类,而是从 passport-jwt 导入。

于 2020-05-11T16:02:58.527 回答