inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[개정3판] Node.js 교과서 - 기본부터 프로젝트 실습까지

9장 데이터베이스 세팅하기 질문있습니다.

171

Backend Woonie

작성한 질문수 2

0

20분 정도에서 말씀주신 내용처럼 콘솔을 찍어보려고 하는데 다음과 같은 에러가 발생했습니다.

C:\developing\zeroCho\nodeJs\nodebird\models\index.js:19
      file.index(".") !== 0 && file !== basename && file.slice(-3) === ".js"
           ^

TypeError: file.index is not a function

 

그래서 일단 코드를 다음과 같이 수정했습니다.
[기존 코드: return file.index(".") !== 0 &&...]

fs.readdirSync(__dirname)
  .filter((file) => {
    return (
      !file.startsWith(".") && file !== basename && file.slice(-3) === ".js"
    );


문제는 또 다른 에러가 발생했는데

C:\developing\zeroCho\nodeJs\nodebird\models>node index.js
hashtag.js Hashtag
C:\developing\zeroCho\nodeJs\nodebird\node_modules\sequelize\lib\model.js:662
      throw new Error("No Sequelize instance passed");
      ^

Error: No Sequelize instance passed
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\node_modules\sequelize\lib\model.js:662:13)
    at Hashtag.initiate (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at C:\developing\zeroCho\nodeJs\nodebird\models\index.js:30:11
    at Array.forEach (<anonymous>)
    at Object.<anonymous> (C:\developing\zeroCho\nodeJs\nodebird\models\index.js:25:4)
    at Module._compile (node:internal/modules/cjs/loader:1469:14)
    at Module._extensions..js (node:internal/modules/cjs/loader:1548:10)
    at Module.load (node:internal/modules/cjs/loader:1288:32)
    at Module._load (node:internal/modules/cjs/loader:1104:12)
    at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:174:12)    


그래서 일단 이것도 modules 폴더 내에서 사용된 initate 메서드를 init으로 변경했습니다.
<예시>

const Sequelize = require("sequelize");

class Hashtag extends Sequelize.Model {
  static init(sequelize) {
    Hashtag.init({
      title: {
        type: Sequelize.STRING(15),
        allowNull: false,
        unique: true,
      },
    });
  }
  static associate(db) {}
}

module.exports = Hashtag;

 

그랬더니 이번에는 무한 재귀 에러가 발생하였습니다

C:\developing\zeroCho\nodeJs\nodebird\models>node index.js 
hashtag.js Hashtag
C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5
    Hashtag.init({
            ^

RangeError: Maximum call stack size exceeded
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)
    at Hashtag.init (C:\developing\zeroCho\nodeJs\nodebird\models\hashtag.js:5:13)

Node.js v20.18.0

 

대안은 super.init을 호출하는 것이라고 하는데 제가 지금 해결방향을 제대로 잡고 있는건지 아니면 점점 산으로 가고 있는건지 저 스스로는 판단이 안 됩니다. 사실 이 문제가 전 파트에서 시퀄라이저 진도 나갈 때도 발생했었는데 같은 문제가 다시 발생해서 굉장히 당황스럽습니다.

도움 부탁드립니다.

node.js mysql express typescript

답변 3

0

조성진/컴퓨터공학부(컴퓨터공학전공

class Hashtag extends Sequelize.Model {
  static init(sequelize) {
    Hashtag.init({

위처럼 작성자 분이 작성하신 코드대로 갔을 때 무한 재귀함수가 발생하는 이유는, Hashtag.init() 함수를 정의하는 곳 (2번째 줄) 안에서 다시 Hashtag.init() 함수를 호출 (3번째 줄) 하기 때문입니다.

super.init() 을 활용하는 방식은 Sequelize 5버전에서 일반적으로 사용되던 방식입니다. Sequelize 6 버전 이후부터는 모델 정의 시 Model.init을 직접 호출하는 방식이 권장되니, 제로초님의 방식대로 하는 것이 좋아 보입니다.

0

제로초(조현영)

file.indexOf 입니다

0

Backend Woonie

답변 감사합니다.
하나만 더 여쭤보자면 initate를 init으로 수정할 필요는 없는걸까요?

1

제로초(조현영)

model.initiate 하셔야 합니다.

0

인프런 AI 인턴

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

질문하신 내용을 보니, file.index(".") !== 0 부분에서 오류가 발생하고 있는 것 같습니다. 이는 fs.readdirSync(__dirname)가 배열로 파일 목록을 반환하며, 이 배열 요소를 문자열로 가정하고 사용하고 있는 코드에서 문제가 발생했습니다. 이 오류를 수정하기 위해서 file이 정확하게 문자열임을 가정할 수 있도록 처리해야 합니다.

현재 사용하신 수정된 코드에서 file.startsWith('.')를 이용해 숨김 파일을 걸러주고 계신 점은 잘 처리하신 부분입니다.

이외에도 file.indexOf(".") !== 0 또한 file.startsWith(".")로 대체하여 좀 더 명확하게 코드를 작성할 수 있으며, file이 문자열임을 확실히 하는 방법 중 하나입니다. 이 방법은 파일이 문자열인 경우에만 작동하며, 배열 요소가 항상 문자열로 되어 있는지 확인해 보시는 것도 좋습니다.

아래의 질문들을 참고하면 이 문제와 관련된 더 많은 정보와 해결 방법을 확인할 수 있습니다:

  1. “백엔드 서버에서 index.js 에러”
  2. “ES6 Sequelize.sync error”

해당 게시물에서는 파일 타입에 대한 이해와 관련된 조언을 얻을 수 있으며, 파일 시스템과 관련한 예외 처리 및 디버깅 방법도 확인해 보실 수 있습니다.

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

깃헙 질문

0

79

2

강의 1-1 수업노트의 로드맵 링크가 작동하지 않습니다.

0

74

1

aws - lightsail 이용 관련

0

56

1

4강 http 서버 만들때 ESM방식으로 해도 될까요?

0

78

2

모듈 사용 시 단점이 있나요?

0

79

1

node.js 버전 및 typescript 적용 문의

0

92

2

12.7. 방장기능(강퇴) 질문드립니다.

0

78

2

12.7 socket.js코드 그대로 뱃겨서 했는데, socket.request.session.color가안나오네요

0

67

1

12.7 코드 그대로 뱃겨서 햇는데 스샷같이 오류가뜹니다.

0

73

2

12.7.1스스로 해보기 질문되나요

0

89

3

시퀄라이즈 실습하기 질문드립니다.

0

187

9

<7-5. 시퀄라이즈 사용하기>수업 질문 드립니다.

0

94

2

크롬에서 user id를 인풋에 입력하고 등록하면 404 에러처리 페이지가 뜹니다.

0

110

2

구매 결제관련 질문입니다 !

0

120

1

다수의 supertest 가 실행될 때 force:true로 인한 DB 초기화 문제

0

131

2

node 설치 방법이 전혀다르게 바뀐것 같습니다.

0

147

2

12강 깃허브에 있는 12.7 chat.html 복붙했는데 css오류

0

120

2

무료/프리미엄 동시 소유 시 질문

0

114

1

비주얼 스튜디오 코드로 계속 진행해도 괜찮을까요?

0

134

2

10강 cors에러 localhost:4000으로 접속했을때 에러

1

155

2

webstorm 해결할 수 없는 변수 문제

0

152

2

혹시 몽고DB 쓸거면 MySQL 강의 스킵해도 되나요?

0

147

2

LightSail 실행 중 오류 질문드립니다!

0

198

2

RedisStore 사용법 질문

0

131

2