CWN(CHANGE WITH NEWS) - 해외 보안 연구원, 파이썬에서 프로토타입 오염과 유사한 버그 변종 발견

  • 구름많음영광군1.8℃
  • 맑음의령군4.5℃
  • 구름조금고창1.3℃
  • 구름조금서산-1.7℃
  • 맑음천안-1.8℃
  • 맑음부안1.9℃
  • 맑음영주-2.4℃
  • 구름조금강화-4.4℃
  • 맑음정선군-3.8℃
  • 맑음완도5.6℃
  • 맑음금산1.3℃
  • 맑음거제6.5℃
  • 맑음부여0.4℃
  • 맑음동해0.4℃
  • 맑음강릉-0.5℃
  • 맑음전주1.0℃
  • 구름조금홍성-1.1℃
  • 구름많음보령-0.4℃
  • 맑음서귀포9.9℃
  • 맑음동두천-5.3℃
  • 맑음고산7.8℃
  • 맑음함양군2.8℃
  • 맑음광양시5.5℃
  • 맑음청주-1.3℃
  • 맑음남원2.1℃
  • 맑음여수5.8℃
  • 맑음청송군-0.5℃
  • 맑음서청주-1.8℃
  • 맑음구미2.2℃
  • 맑음장수-1.0℃
  • 맑음철원-5.9℃
  • 맑음원주-2.6℃
  • 맑음순천3.1℃
  • 구름많음목포2.6℃
  • 구름많음울릉도0.3℃
  • 맑음세종-1.0℃
  • 맑음진주5.6℃
  • 맑음대전0.0℃
  • 구름조금광주3.0℃
  • 맑음북춘천-4.4℃
  • 맑음남해5.9℃
  • 맑음진도군3.9℃
  • 맑음춘천-3.7℃
  • 맑음고흥5.0℃
  • 맑음김해시6.2℃
  • 맑음순창군1.8℃
  • 맑음대관령-8.7℃
  • 맑음경주시4.3℃
  • 맑음산청2.8℃
  • 맑음북창원6.3℃
  • 맑음합천5.5℃
  • 맑음북부산6.9℃
  • 맑음창원5.7℃
  • 맑음울산5.0℃
  • 맑음보은-1.3℃
  • 맑음서울-2.8℃
  • 구름많음흑산도4.2℃
  • 구름조금파주-4.9℃
  • 맑음통영6.4℃
  • 맑음북강릉-1.3℃
  • 맑음거창2.9℃
  • 맑음울진1.6℃
  • 맑음장흥4.7℃
  • 맑음수원-2.7℃
  • 구름많음백령도-3.5℃
  • 맑음영월-2.7℃
  • 맑음상주-0.4℃
  • 구름조금고창군1.7℃
  • 맑음밀양6.2℃
  • 맑음강진군4.5℃
  • 맑음의성1.1℃
  • 맑음홍천-3.5℃
  • 구름조금양평-2.5℃
  • 맑음해남4.1℃
  • 맑음임실0.4℃
  • 구름조금성산7.6℃
  • 맑음보성군4.9℃
  • 맑음제천-3.2℃
  • 맑음안동-0.4℃
  • 맑음군산0.3℃
  • 맑음속초-2.0℃
  • 맑음양산시7.0℃
  • 맑음영덕1.9℃
  • 맑음충주-2.5℃
  • 맑음인제-4.4℃
  • 맑음영천2.7℃
  • 구름조금정읍1.0℃
  • 구름조금이천-2.5℃
  • 구름조금제주8.0℃
  • 맑음대구4.1℃
  • 맑음인천-3.8℃
  • 맑음포항4.2℃
  • 맑음문경-1.7℃
  • 맑음추풍령-0.4℃
  • 맑음태백-6.3℃
  • 맑음봉화-2.8℃
  • 맑음부산6.9℃
  • 2026.01.13 (화)

해외 보안 연구원, 파이썬에서 프로토타입 오염과 유사한 버그 변종 발견

안하영 / 기사승인 : 2023-01-13 12:44:32
  • -
  • +
  • 인쇄
파이썬에서 프로토타입 오염 변종이 발견됐다. [사진출처=파이썬]
파이썬에서 프로토타입 오염 변종이 발견됐다. [사진출처=파이썬]

파이썬에서 프로토타입 오염 변종이 발견됐다. 프로토타입 오염은 프로토타입 기반 언어와 관련된 위험한 버그로, 자바스크립트에서 기승을 부리는 것으로 알려졌다.

그러나 해외 테크 매체 포스트스위거는 사이버 보안 연구원 압둘라힘 칼레드(Abdulraheem Khaled)가 파이썬에도 프로토타입 오염이 적용된 사실을 발견했다고 보도했다. 칼레드는 다른 클래스 기반 프로그래밍 언어도 프로토타입 오염의 영향을 받았을 가능성도 경고하며, 해당 공격 유형을 ‘클래스 오염(class pollution)’이라고 칭했다.

클래스 오염은 자바스크립트 프로토타입 오염의 개념을 파이썬으로 변환하려고 시도하는 동안 발생했다.

파이썬 개체를 오염시키기 위해 공격자는 사용자 입력을 사용해 개체의 특성을 설정한다. 사용자 입력이 속성 이름과 값을 모두 결정하는 경우 공격자는 이를 악용해 프로그램 동작을 조작할 수 있다.

대상 함수가 재귀 루프를 사용해 개체의 특성을 순회하는 경우 공격자는 잠재적으로 상위 클래스, 전역 변수 등에 대한 액세스 권한을 얻을 수 있다.

예를 들어, 공격자는 이러한 기능을 사용해 시스템에서 실행되는 명령 문자열을 수정하고, 중요한 변수의 값을 변경한다. 이를 통해 중요한 클래스를 기능 장애로 만들어 서비스 거부 공격(DoS)을 일으킬 수 있다.

매체는 모든 종류의 파이썬 응용 프로그램이 정제되지 않은 사용자 입력을 받고 안전하지 않은 개체 속성 할당 형식을 구현하는 한 이러한 유형의 공격에 취약할 수 있다고 설명했다.

클래스 오염의 최소 영향은 DoS이다. 하지만 공격은 잠재적으로 다음과 같은 파이썬 웹 애플리케이션에 더 깊은 영향을 미칠 수 있다.

Flask 웹 애플리케이션에서 세션에 서명하는 데 사용되는 비밀 키를 덮어쓰고 유효한 세션을 수동으로 만들어 계정 탈취 공격을 준비할 때는 더 취약해진다.

필터 우회를 할 때도 클래스 오염에 취약할 수 있다. 예를 들어 템플릿 파일을 로드하려고 할 때 Jinja에 구현된 경로 통과 방지를 우회한다. 이는 공격자가 템플릿 디렉토리에 제한받지 않고 모든 로컬 디렉토리에서 파일을 로드할 수 있도록 함으로써 로컬 파일 공개로 이어진다. COMSPEC 또는 PATH 환경 변수를 덮어써서 원격 명령을 실행하는 경우에도 취약할 수 있다.

매체는 “클래스 오염은 확실히 커뮤니티에서 더 많은 관심을 기울여야 하는 주제 중 하나로 주목받기 시작했다”며, “클래스 오염은 이제 막 밝혀진 새로운 취약점일 수 있지만, 곧 다른 프로그래밍 언어에서도 발생할 것으로 보인다”라고 전했다.

[저작권자ⓒ CWN(CHANGE WITH NEWS). 무단전재-재배포 금지]

안하영
안하영

기자의 인기기사

최신기사

뉴스댓글 >

- 띄어 쓰기를 포함하여 250자 이내로 써주세요.
- 건전한 토론문화를 위해, 타인에게 불쾌감을 주는 욕설/비방/허위/명예훼손/도배 등의 댓글은 표시가 제한됩니다.

댓글 0

Today

Hot Issue