본문으로 건너뛰기
피드

ChatGPT의 Cloudflare Turnstile 분석: React 내부 상태까지 검사하는 봇 탐지

security 약 6분
vote
0
댓글
북마크

Cloudflare Turnstile이 ChatGPT에서 377개 프로그램을 복호화한 결과, 브라우저 핑거프린팅을 넘어 React 내부 상태(__reactRouterContext 등)까지 검증하는 애플리케이션 레벨 봇 탐지를 수행하고 있었음. XOR 암호화 키가 동일 페이로드에 포함되어 분석 자체는 방지하지 못하는 구조임.

  • 1

    377개 Turnstile 프로그램 100% 복호화 성공

  • 2

    3계층 55개 속성 검사: 브라우저 핑거프린트, Cloudflare 네트워크, React 앱 상태

  • 3

    React Router 내부 상태 검증 — SPA를 실제 렌더링하지 않는 봇은 차단됨

  • 4

    XOR 암호화 키가 같은 데이터 스트림에 포함 — 난독화 수준

  • 5

    Signal Orchestrator로 키 입력 타이밍·마우스 속도 등 행동 생체인식도 수행

ChatGPT의 Cloudflare Turnstile 봇 탐지 — React 내부 상태까지 검사함

  • ChatGPT 메시지를 보낼 때마다 Cloudflare Turnstile 프로그램이 브라우저에서 조용히 실행됨
    • 네트워크 트래픽에서 377개 프로그램을 복호화해 분석한 결과
    • 표준 브라우저 핑거프린팅을 넘어서는 수준이었음

3계층 55개 속성 검사

  • Layer 1 — 브라우저 핑거프린트 (38개 속성)
    • WebGL 8개: UNMASKED_VENDOR/RENDERER, debug_renderer_info 등
    • 화면 8개: colorDepth, pixelDepth, width/height, availWidth/Height 등
    • 하드웨어 5개: hardwareConcurrency, deviceMemory, maxTouchPoints 등
    • 폰트 측정 4개: 숨겨진 div 생성 → 폰트 렌더링 크기 측정 → 제거
    • DOM 프로빙 8개, 스토리지 5개 (localStorage에 핑거프린트 영구 저장)
  • Layer 2 — Cloudflare 네트워크 (5개 속성)
    • cfIpCity, cfIpLatitude/Longitude, cfConnectingIp, userRegion
    • Cloudflare Edge를 거치지 않으면 값이 없거나 불일치
  • Layer 3 — 애플리케이션 상태 (3개 속성) ← 핵심 발견
    • __reactRouterContext, loaderData, clientBootstrap
    • React Router v6+가 DOM에 부착하는 내부 구조체
    • ChatGPT React 앱이 완전히 렌더링·hydration 되어야만 존재
    • 브라우저 API만 스텁하고 React를 실행하지 않는 봇은 실패함

중요

> Turnstile은 브라우저 계층이 아닌 애플리케이션 계층에서 봇 탐지를 수행함. 브라우저 핑거프린트를 완벽히 위조해도 ChatGPT SPA를 실제로 렌더링하지 않으면 차단됨.

암호화 구조 — 키가 페이로드 안에 있음

  • Turnstile 바이트코드는 암호화되어 도착함
    • 외부 레이어: turnstile.dx (매 요청 28,000자 base64)를 prepare 요청의 p 토큰으로 XOR → 89개 VM 명령어
    • 내부 레이어: 19KB 암호화 blob, XOR 키는 바이트코드 내 float 리터럴로 포함됨
    • 50개 요청 검증 결과 50/50 성공 — 키가 같은 데이터 스트림에 존재
  • 복호화에 HTTP 요청/응답 외에 아무것도 필요 없음
    • 캐주얼한 검사는 방지하지만, 분석은 방지하지 못함

추가 방어 레이어

  • Signal Orchestrator (271개 명령어): 행동 생체인식 레이어
    • keydown, pointermove, click, scroll, paste, wheel 이벤트 리스너
    • 36개 window.__oai_so_* 속성으로 키 입력 타이밍, 마우스 속도, 스크롤 패턴, 유휴 시간 추적
  • Proof of Work (25개 필드 핑거프린트 + SHA-256 hashcash)
    • 난이도 400K~500K, 72%가 5ms 이내 solve
    • 7개 바이너리 탐지 플래그 (ai, createPRNG, cache, solana 등) — 100개 샘플 전부 0

분석 결과 수치

  • 복호화 프로그램: 377/377 (100%)
  • 관찰된 고유 사용자: 32명
  • 프로그램당 속성: 55개 (전 샘플 동일)
  • 프로그램당 명령어: 417~580개 (평균 480)
  • 고유 XOR 키 (50개 샘플): 41개
  • SO 행동 속성: 36개
  • PoW 핑거프린트 필드: 25개

기술 맥락

Cloudflare Turnstile이 단순 CAPTCHA 대체를 넘어 애플리케이션 레벨 봇 탐지로 진화한 사례임. React 내부 상태(__reactRouterContext 등)를 검증한다는 것은 headless 브라우저나 API 직접 호출 방식의 봇이 근본적으로 차단된다는 의미임. XOR 암호화의 키가 동일 스트림에 포함되어 있어 보안보다는 난독화에 가까운 구조이지만, 운영 목적(정적 분석 방지, 요청별 고유 토큰 생성, 체크 항목 은닉)에는 충분히 효과적임.

봇 탐지가 브라우저 레벨에서 애플리케이션 레벨로 진화한 중요한 사례임. SPA 기반 서비스 개발 시 프레임워크 내부 상태가 보안 시그널로 활용될 수 있다는 점을 인지해야 함.

댓글

댓글

댓글을 불러오는 중...

security

한양대 에리카와 네이버클라우드, 클라우드·보안·AI 인재 키우는 산학협력 체결

한양대 에리카가 네이버클라우드와 첨단 분야 지역인재 양성과 글로벌 산학협력을 위한 업무협약을 맺었다. 협력 범위는 클라우드, 사이버보안, 블록체인, 개인정보보호, 인공지능(AI), 디지털 전환(DX) 교육·연구 기반 구축까지 포함된다.

security

악성 npm 패키지가 AI 개발도구의 지침 파일과 MCP까지 노리기 시작함

이스트시큐리티가 웹과 탈중앙화금융 개발자를 겨냥한 악성 npm 패키지 캠페인을 포착했어. 공격자는 유명 웹3 도구를 사칭하는 데서 그치지 않고, AI 에이전트가 읽는 프로젝트 지침 파일과 MCP 기반 외부 도구 호출까지 공격 경로로 삼으려 했어.

security

금융권, 앤트로픽 미토스가 찾은 오픈소스 취약점에 긴급 점검 들어감

앤트로픽의 AI 모델 클로드 미토스가 1000개 넘는 오픈소스에서 대량의 취약점 후보를 찾아냈고, 그중 일부가 실제 취약점으로 검증돼 공개됐어. 금융당국은 nginx, wolfSSL, FreeRDP, Ghost 같은 널리 쓰이는 구성요소를 중심으로 금융권에 긴급 자산 점검과 패치 적용을 권고했어.

security

애플이 양자 내성 암호화 검증 코드를 공개했다, 핵심은 수학적 증명

애플이 corecrypto 라이브러리의 포스트 양자 암호화 구현과 검증 코드를 GitHub에 공개했다. ML-KEM, ML-DSA 구현과 형식 검증 접근을 공개해 보안 연구자들이 직접 검토할 수 있게 했고, 이 기술은 25억 대 이상 활성 기기에서 쓰이는 암호화 기반과 연결된다.

security

라라벨 번역 패키지 태그가 통째로 바뀌었다, 개발자 비밀값 털리는 공급망 공격

전 세계 라라벨 개발자가 쓰는 Laravel-Lang 패키지가 공격을 받아 Git 태그가 악성 버전을 가리키도록 바뀌었다. 5월 22일 약 90분 동안 4개 저장소의 태그가 교체됐고, 감염된 패키지는 AWS 키, GitHub 토큰, Stripe 시크릿, 암호화폐 지갑 복구 구문, SSH 개인키 등을 노렸다.