inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

클로드 코드 완벽 마스터: AI 개발 워크플로우 기초부터 실전까지

🔥[MISSION 13] 미션 소개🔥

hook으로 특정파일 접근 막기 vs settings.json으로 접근 막기

64

balcony

작성한 질문수 1

0

제목 그대로 둘이 어떤 차이점이 있나요?

 

어떤 방법을 어떤 상황에서 사용하는게 좋나요?

 

차이가 없어보이는데 settings.json의 경우 할루시네이션이나 확률적으로 작동해서 hook으로 설정을 더 추천하는 걸까요?

react 인공지능(ai) claude

답변 2

0

짐코딩

안녕하세요! 🙂

결론부터 말씀드리면, 둘 다 시스템 레벨에서 작동하기 때문에 할루시네이션으로 뚫리는 건 아닙니다.

settings.jsonpermissions.deny는 특정 파일이나 명령어를 패턴으로 차단하는 방식이에요. Read(./.env), Bash(rm -rf *) 같은 식으로 와일드카드도 지원하고, 설정만 넣으면 바로 동작해서 간편합니다.

hooksPreToolUse는 도구 실행 직전에 외부 스크립트를 돌려서 검증하는 방식이에요. 단순 패턴 매칭으로 안 되는 복잡한 조건이 필요할 때 씁니다. 예를 들어 Bash 명령어 안에 담긴 SQL 내용을 파싱해서 SELECT만 허용하고 INSERT/DELETE는 막는다거나 하는 건 settings.json만으로는 어려워요. 그리고 hooks는 차단만 하는 게 아니라 도구 실행 후 자동으로 린터를 돌리거나, 입력값을 중간에 수정해서 전달하는 것도 가능합니다.

정리하면, 단순하게 "이 파일 못 읽게 / 이 명령어 못 쓰게" 수준이면 settings.json으로 충분하고, 명령어 내용을 직접 분석하거나 실행 전후로 뭔가 추가 동작이 필요하면 hooks를 쓰는 거예요 👍

감사합니다 🙏

0

인프런 AI 인턴

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

클로드 코드에서 특정 파일의 접근 제어에 관하여 고민이 있으신 것 같습니다. 파일 접근을 제한하는 두 가지 방법, 즉 Hook과 settings.json에 대해 설명드리겠습니다.

1. Hook

  • 주요 기능: 주로 코드를 실행하기 전에 특정 조건을 검증하고, 이벤트나 조건에 따라 실행을 제어합니다.
  • 사용 사례: 프로젝트 내에서 개발자가 직접 특정 파일이나 폴더에 대한 접근을 ‘강화된 제어’ 방식으로 설정하고자 할 때 주로 사용됩니다.
  • 장점: 명시적이고 조건부 실행이 가능하기 때문에 복잡한 규칙 설정이 가능합니다.

2. settings.json

  • 주요 기능: 클로드 코드에서 사전에 설정된 파일 접근 권한을 정의할 수 있습니다.
  • 사용 사례: 특정 경로에 대한 전역적이고 일관된 접근 제한을 설정하고자 할 때 사용됩니다.
  • 장점: 간단하게 설정이 가능하며, 한 번의 설정으로 전반적인 파일 접근을 제어할 수 있습니다.

추천 방법

  • Hook 사용: 프로젝트의 복잡한 파일 접근 제어가 필요한 경우나, 조건에 따라 동적으로 제어해야 하는 경우를 생각할 때 유리합니다.
  • settings.json 사용: 상대적으로 간단한 전역 설정이 필요한 경우, 설정 파일을 통해 쉽게 제어할 수 있어 보편적으로 사용됩니다.

여기에서 추가로 알아두실 것은, 이 두 가지 방법이 서로 보완적으로 사용될 수 있습니다. 즉, 기본적인 접근 제한은 settings.json으로 설정하고, 복잡한 규칙이나 동적 제어가 필요한 부분에 Hook을 추가할 수 있습니다.

원하시는 방식에 따라 두 방법을 적절히 혼합하여 사용하는 것이 좋습니다. 아래와 같은 유사한 상담을 통해 여러분의 활용 방식에 대한 정보를 더 얻으실 수 있습니다.

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

파워셀에서 claude 코드의 버전확인이 않됩니다.

0

11

2

윈도우에서 설정화면이 다릅니다.클로드코드 환경변수 설정

0

12

2

깃허브 Publish 질문

0

14

2

클로드 코드 프로 사용자인데..

0

15

2

강의는 순서대로 들어야 할까요??

0

14

1

supabase 사용 관련.

0

17

2

문서 업데이트

0

27

2

/init

0

33

2

이미지내 텍스트 인식시키는 방법

0

20

1

문서, 파일, 웹사이트 참고 관련

0

18

2

vs code에서 클로드 설정

0

26

2

서브에이전트 복사 관련

0

19

2

prd 생성 서브에이전트 description 관련

0

18

2

94강 PRD 문서 검토 서브에이전트 관련 질문드려요.

0

19

2

init 오류

0

24

2

task manager 사용시 서브에이전트 개입 관련

0

22

3

카드뉴스 제작 시 CSS 사용 관련

0

21

2

165강 카드뉴스 관련 질문드려요.

0

27

2

CLAUDE.md 분산관리 관련 질문드려요.

0

23

2

github 사례 적용 방법

0

20

1

프로젝트 도입 관련

0

20

1

서브에이전트와 팀에이전트 관련

0

21

2

161강에서 소개해 주신 CLAUDE.md 파일 적용 관련

0

23

2

강의 따라 하는데 강의에서 갑자가 생성되는 폴더는?

0

25

2