# Claude Code CLI 출력을 슬랙에 전달하는 방법 > **작성일**: 2026-03-11 > **대상**: 슬랙으로 협업하는 모든 팀원 --- ## 1. 문제 Claude Code CLI에서 복사한 텍스트를 슬랙 채팅창에 붙여넣으면 줄바꿈이 깨지고, 마크다운 문법이 원본 그대로 노출된다. --- ## 2. 원인 분석 텍스트가 깨지는 원인은 3가지가 복합적으로 작용한다. ### 2.1 터미널 줄바꿈 혼재 터미널에는 2종류의 줄바꿈이 존재한다. | 종류 | 설명 | 복사 시 동작 | |------|------|-------------| | Hard wrap | 원본 텍스트의 실제 `\n` | 보통 유지됨 | | Soft wrap | 터미널 창 너비에 의한 시각적 줄바꿈 | 유실되거나 불필요하게 추가됨 | Claude Code CLI는 터미널에서 실행되므로, 드래그 복사 시 실제 줄바꿈과 시각적 줄바꿈이 뒤섞여 클립보드에 들어간다. 그 결과 어떤 줄은 합쳐지고, 어떤 줄은 엉뚱한 곳에서 끊어진다. ### 2.2 Markdown vs Slack mrkdwn 문법 차이 Claude Code는 표준 Markdown을 출력하지만, 슬랙은 자체 마크업 문법(mrkdwn)을 사용한다. | 요소 | Markdown (Claude Code) | Slack mrkdwn | 직접 붙여넣기 시 | |------|----------------------|-------------|----------------| | 볼드 | `**텍스트**` | `*텍스트*` | `**텍스트**` 그대로 표시 | | 이탤릭 | `*텍스트*` | `_텍스트_` | 슬랙에서 볼드로 오인식 | | 제목 | `## 제목` | 지원 안 함 | `## 제목` 그대로 표시 | | 취소선 | `~~텍스트~~` | `~텍스트~` | `~~텍스트~~` 그대로 표시 | | 링크 | `[텍스트](URL)` | `` | 원본 문법 그대로 표시 | | 구분선 | `---` | 지원 안 함 | `---` 대시 3개로 표시 | | 코드블록 | ` ```lang ``` ` | ` ``` ``` ` | 언어 지정자가 텍스트로 노출될 수 있음 | ### 2.3 슬랙 입력창의 공백 처리 슬랙의 메시지 입력창은 붙여넣기 시 다음 처리를 수행한다: - 연속 빈 줄을 1개로 축소 - 앞뒤 공백 제거 - 일부 특수문자 이스케이프 이 3가지가 합쳐지면 **줄 합침, 문법 노출, 공백 손실**이 동시에 발생한다. --- ## 3. 해결 방법: 클코 → 슬랙 변환기 ### 3.1 접속 경로 MNG 관리자 패널에 변환 도구가 있다. | 환경 | URL | |------|-----| | 로컬 | `http://mng.sam.kr/rd/cc-to-slack` | | 개발 서버 | `https://admin.codebridge-x.com/rd/cc-to-slack` | | 운영 서버 | `https://mng.codebridge-x.com/rd/cc-to-slack` | **메뉴 위치**: 연구개발 > 클코 to 슬랙형태 ### 3.2 사용법 1. Claude Code CLI에서 메시지를 드래그하여 복사 (`Ctrl+C`) 2. 변환기의 왼쪽 입력란에 붙여넣기 (`Ctrl+V`) 3. 오른쪽 슬랙 미리보기에 변환 결과가 자동 표시됨 4. **복사** 버튼 클릭 (또는 `Ctrl+Enter`) 5. 슬랙 채팅창에 붙여넣기 (`Ctrl+V`) ### 3.3 변환 규칙 | 변환 전 (Markdown) | 변환 후 (Slack) | 설명 | |-------------------|----------------|------| | `**볼드**` | `*볼드*` | 슬랙 볼드 문법 | | `## 제목` | `*제목*` | 볼드 처리로 대체 | | `~~취소~~` | `~취소~` | 슬랙 취소선 문법 | | `[텍스트](URL)` | `` | 슬랙 링크 문법 | | `---` | `———` | em dash로 구분선 대체 | | 테이블 구분선 `\|---\|` | 제거 | 불필요한 구분선 삭제 | | 연속 빈 줄 | 1개로 정리 | 공백 정리 | | 코드블록 | 유지 | 슬랙도 ` ``` ` 지원 | --- ## 4. 작동 원리 변환기가 정상 작동하는 핵심 이유는 **리치 텍스트(HTML) 복사** 방식을 사용하기 때문이다. ``` 일반 텍스트 복사 (plain text) → 슬랙이 자체적으로 재해석 → 줄바꿈 깨짐, 문법 노출 리치 텍스트 복사 (HTML) → 슬랙이 HTML 서식을 그대로 수용 → 볼드, 코드블록, 줄바꿈 보존 ``` 브라우저의 Selection API로 DOM 요소를 선택하면 클립보드에 `text/html`과 `text/plain` 두 가지 형식이 동시에 저장된다. 슬랙은 `text/html` 버전을 읽어서 ``, ``, `
` 등의 서식을 그대로 적용한다. --- ## 관련 문서 - MNG 소스: `mng/resources/views/rd/cc-to-slack/index.blade.php` - 컨트롤러: `mng/app/Http/Controllers/RdController.php` — `ccToSlack()` - 라우트: `GET /rd/cc-to-slack` --- **최종 업데이트**: 2026-03-11