인프런 커뮤니티 질문&답변
hook으로 특정파일 접근 막기 vs settings.json으로 접근 막기
작성
·
54
퀴즈
Claude Code Hooks의 주된 목적은 무엇일까요?
Claude Code 학습 데이터 수집
LLM의 확률적 특성 제어
개발 환경 일관성 유지 및 자동화
Claude Code 내부 로직 변경
답변 2
0
안녕하세요! 🙂
결론부터 말씀드리면, 둘 다 시스템 레벨에서 작동하기 때문에 할루시네이션으로 뚫리는 건 아닙니다.
settings.json의 permissions.deny는 특정 파일이나 명령어를 패턴으로 차단하는 방식이에요. Read(./.env), Bash(rm -rf *) 같은 식으로 와일드카드도 지원하고, 설정만 넣으면 바로 동작해서 간편합니다.
hooks의 PreToolUse는 도구 실행 직전에 외부 스크립트를 돌려서 검증하는 방식이에요. 단순 패턴 매칭으로 안 되는 복잡한 조건이 필요할 때 씁니다. 예를 들어 Bash 명령어 안에 담긴 SQL 내용을 파싱해서 SELECT만 허용하고 INSERT/DELETE는 막는다거나 하는 건 settings.json만으로는 어려워요. 그리고 hooks는 차단만 하는 게 아니라 도구 실행 후 자동으로 린터를 돌리거나, 입력값을 중간에 수정해서 전달하는 것도 가능합니다.
정리하면, 단순하게 "이 파일 못 읽게 / 이 명령어 못 쓰게" 수준이면 settings.json으로 충분하고, 명령어 내용을 직접 분석하거나 실행 전후로 뭔가 추가 동작이 필요하면 hooks를 쓰는 거예요 👍
감사합니다 🙏
0
안녕하세요, 인프런 AI 인턴입니다. Balcony님.
클로드 코드에서 특정 파일의 접근 제어에 관하여 고민이 있으신 것 같습니다. 파일 접근을 제한하는 두 가지 방법, 즉 Hook과 settings.json에 대해 설명드리겠습니다.
1. Hook
- 주요 기능: 주로 코드를 실행하기 전에 특정 조건을 검증하고, 이벤트나 조건에 따라 실행을 제어합니다.
- 사용 사례: 프로젝트 내에서 개발자가 직접 특정 파일이나 폴더에 대한 접근을 ‘강화된 제어’ 방식으로 설정하고자 할 때 주로 사용됩니다.
- 장점: 명시적이고 조건부 실행이 가능하기 때문에 복잡한 규칙 설정이 가능합니다.
2. settings.json
- 주요 기능: 클로드 코드에서 사전에 설정된 파일 접근 권한을 정의할 수 있습니다.
- 사용 사례: 특정 경로에 대한 전역적이고 일관된 접근 제한을 설정하고자 할 때 사용됩니다.
- 장점: 간단하게 설정이 가능하며, 한 번의 설정으로 전반적인 파일 접근을 제어할 수 있습니다.
추천 방법
- Hook 사용: 프로젝트의 복잡한 파일 접근 제어가 필요한 경우나, 조건에 따라 동적으로 제어해야 하는 경우를 생각할 때 유리합니다.
- settings.json 사용: 상대적으로 간단한 전역 설정이 필요한 경우, 설정 파일을 통해 쉽게 제어할 수 있어 보편적으로 사용됩니다.
여기에서 추가로 알아두실 것은, 이 두 가지 방법이 서로 보완적으로 사용될 수 있습니다. 즉, 기본적인 접근 제한은 settings.json으로 설정하고, 복잡한 규칙이나 동적 제어가 필요한 부분에 Hook을 추가할 수 있습니다.
원하시는 방식에 따라 두 방법을 적절히 혼합하여 사용하는 것이 좋습니다. 아래와 같은 유사한 상담을 통해 여러분의 활용 방식에 대한 정보를 더 얻으실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.




