inflearn logo
강의

Course

Instructor

Solid backend NestJS, from basics to advanced

JWT and Login Service & Circular Reference Module

jwt를 따로 연습하고 있는데 env를 못읽는 것 같습니다.

314

작성자 없음

0 asked

0

import { Module } from '@nestjs/common'; import { AuthController } from './auth.controller'; import { AuthService } from './auth.service'; import { ConfigModule } from '@nestjs/config'; import { PassportModule } from '@nestjs/passport'; import { JwtModule } from '@nestjs/jwt'; import { JwtStrategy } from 'src/auth/jwt/jwt.strategy'; @Module({ imports: [ ConfigModule.forRoot({ isGlobal: true, envFilePath: `.env.${process.env.NODE_ENV}`, }), PassportModule.register({ defaultStrategy: 'jwt', session: false }), JwtModule.register({ secret: process.env.JWT_SECRET, signOptions: { expiresIn: '1y' }, }), ], controllers: [AuthController], providers: [AuthService, JwtStrategy], }) export class AuthModule {}이게 auth.module.ts 파일입니다import { Injectable } from '@nestjs/common'; import { PassportStrategy } from '@nestjs/passport'; import { ExtractJwt, Strategy } from 'passport-jwt'; @Injectable() export class JwtStrategy extends PassportStrategy(Strategy) { constructor() { super({ jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(), ignoreExpiration: false, secretOrKey: process.env.JWT_SECRET, }); } async validate() {} }여기서 문제가 일어났습니다. process.env.JWT_SECRET 이 것을 읽지 못합니다.NODE_ENV="development" JWT_SECRET="secret" PORT=8000.env.development 파일도 root폴더에 잘 있습니다. 무엇이 문제인지 잘 모르겠습니다

node.js mongodb express nestjs ssr

Answer 2

0

tjdrbs205

작성자분이 보실진 모르겠지만 비슷한 상황이신분들에게 도움될까 적어봐요

JwtModule.register 사용하시는 경우 로드 순서때문에 env파일을 로드하기전에 JwtModule이 먼저 읽어 버리기에 생기는 문제일 가능성이 높습니다.
이부분을 해결하기위해 registerAsync메서드를 사용해서
useFactory에 세팅값을 함수 형태로 담아두시면 됩니다.

스크린샷 2025-02-14 오후 8.42.33.png.webp


이런 형태로 해주시면 env파일을 불러올거에요.

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

재일 조님의 질문 상황은 .env 파일에서 환경 변수를 읽어오는 것에 문제가 있어 보입니다. 특히, JWT_SECRET 환경 변수를 읽지 못하는 이슈입니다.

이와 관련하여 비슷한 상황의 질문을 찾았습니다. 환경변수가 안 넘어 옵니다.에서 한 수강생이 .env 파일을 사용하여 환경 변수를 설정했는데 특정 환경 변수를 읽지 못하는 문제를 겪었습니다. 이에 대한 답변으로 .env 파일의 존재 여부와 ConfigModule 설정 등을 확인해보라는 조언을 주고 있습니다.

또한, process.env 를 읽지못하는것같습니다. 질문에서는 ConfigModule의 올바른 import와 설정을 강조하고 있습니다.

위의 두 질문 및 답변에서 다뤄진 내용이 재일 조님께 도움이 될 것으로 보입니다. 특히, ConfigModule 설정을 확인하고 .env 파일이 올바른 위치에 존재하는지 확인해보시기 바랍니다. 환경 변수 파일명이 envFilePath 옵션에서 설정한 것과 정확하게 일치하는지도 중요한 체크 포인트입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

프로젝트 환경 세팅할 때 최신 노드 버젼을 사용하시는 분들은 참고하셔도 좋을 것 같아요~

2

77

1

DTO에 대한 질문

1

86

2

백엔드 MVC에서 View의 역할은 무엇인가요?

1

90

2

추가 업데이트 관련 건

0

89

2

nest js 버전문제

0

79

2

mongdb 스키마 공식 문서와 형태가 다른 이유 궁금합니다.

0

103

1

라인 끝에 에러 표시(eslint) 때문에 구글 찾아 보니.

0

72

1

전체 고양이 조회 라우터 중 error.message 오류

0

66

1

캡슐화 추가 설명 중 단일책임원칙 관련 질문

0

103

0

TypeORM과 mysql을 사용하시는 분들

4

140

1

42강 고양이끼리 소통 댓글 구현 중 Schema hasn't been registered for model 'comments' 에러 해결

0

80

1

채팅 이슈

0

132

1

모듈이 더 이상 지원하지 않는답니다

0

205

1

오류가 있습니다

0

105

1

import 에서 오류가 납니다

0

126

1

이런 오류가 나옵니다

0

99

1

에러가 발생합니다

0

108

1

프론트 에러 뜨는데 수정 안해주시나요

0

154

1

emit() broadcast.emit() 질문있습니다

0

99

1

서버연결이 안됩니다.

1

400

1

[PM2][ERROR] Command not found

0

515

1

S3에 업로드까지는 성공했는데 사진이 나오지 않습니다.

0

240

1

error_code : Property 'user' does not exist on type 'Request<ParamsDictionary, any, any, ParsedQs, Record<string, any>>'.ts(2339)

0

597

1

Ec2로 안하시는 이유가 있을까요?

0

339

1