본문으로 건너뛰기
피드

Android 15에서 .ogg 파일이 .ogg.ogx로 다운로드되는 이유 — 18년 된 MIME 타입의 복수

backend 약 3분
vote
0
댓글
북마크

Android 15의 guessFileNameRfc6266 함수가 서버에서 application/ogg로 보낸 .ogg 파일에 .ogx 확장자를 덧붙여 이중 확장자를 만드는 문제. Android 버그가 아니라 18년 전 설정된 서버 MIME 타입 구성 문제이며, Wikimedia 등 대형 사이트에서도 발생했음.

  • 1

    Android 15부터 파일명 확장자와 MIME 타입 불일치 시 확장자를 교체 대신 덧붙이는 방식으로 변경

  • 2

    application/ogg는 RFC 5334에서 멀티플렉싱 데이터용으로 재정의되어 오디오에는 audio/ogg를 써야 함

  • 3

    Wikimedia는 Phabricator T420422로 다음 날 수정 완료

  • 4

    Apache와 nginx에서 올바른 MIME 타입 매핑 설정 방법 제공

  • Android 15부터 guessFileNameRfc6266 함수가 파일명과 MIME 타입의 확장자가 다를 경우 확장자를 교체하지 않고 뒤에 덧붙이는 방식으로 변경됨
  • 서버가 .ogg 파일을 application/ogg로 보내면 Android가 .ogx 확장자를 추가해 .ogg.ogx라는 이중 확장자가 생성됨
  • Wikimedia, Fandom/WikiA 등 대형 사이트들이 실제로 application/ogg를 기본 Content-Type으로 사용 중이었음
  • RFC 5334에서 application/ogg는 멀티플렉싱된 데이터용으로 재정의되었고, 오디오 파일에는 audio/ogg를 써야 맞음
  • 18년 전 설정된 MIME 타입 구성이 문제없이 돌아가다가 Android 15의 로직 변경으로 한꺼번에 터진 상황

서버 측 수정 방법

  • Apache (.htaccess 또는 mime.conf):
    AddType audio/ogg .ogg .oga .spx .opus
    AddType video/ogg .ogv
    AddType application/ogg .ogx
  • nginx (mime.types):
    audio/ogg ogg oga spx opus;
    video/ogg ogv;
    application/ogg ogx;
  • Wikimedia는 Phabricator T420422를 통해 이미 수정 완료됨 — 제보 다음 날 패치가 나감
  • 데스크톱 브라우저(Firefox, Chrome, Safari)에서는 재현되지 않으며, Android 15+ 기기에서만 발생하는 문제임
  • .ogx 파일 자체는 정상 재생되지만, 파일 공유 시 확장자 혼란이 발생함

18년간 문제없이 돌아가던 서버 설정이 클라이언트 로직 하나의 변경으로 한꺼번에 깨질 수 있다는 점에서, MIME 타입 같은 웹 표준의 정확한 준수가 여전히 중요함을 보여줌.

댓글

댓글

댓글을 불러오는 중...

backend

Go에서 Rust로 옮길 때 진짜로 바뀌는 것들

이 글은 Go 백엔드 서비스를 Rust로 옮길 때 속도보다 컴파일 타임 보장, 런타임 트레이드오프, 개발자 경험이 더 중요하다고 설명한다. nil 패닉, 데이터 레이스, 에러 처리, 제네릭, 비동기 모델, 마이그레이션 전략까지 실무 관점에서 Go와 Rust를 길게 비교한다.

backend

Python 3.15에서 헤드라인은 못 탔지만 꽤 쓸만한 기능들

Python 3.15에는 lazy imports나 Tachyon profiler 같은 큰 기능 말고도 실무에서 바로 체감될 만한 작은 개선들이 들어가. TaskGroup 취소, 컨텍스트 매니저 데코레이터 개선, 스레드 안전 이터레이터처럼 평소 애매하게 불편했던 지점들이 꽤 깔끔해졌어.

backend

심평원, DUR부터 의료영상 심사까지 클라우드로 갈아엎는다

심평원이 정보시스템 클라우드 전환과 함께 병·의원 업무에 직접 닿는 DUR, 의료영상 AI 심사, 요양급여내역 조회 시스템을 고도화한다. 핵심은 설치형 프로그램 중심이던 연계를 웹과 API 기반으로 넓히고, 진료·청구 과정에서 실시간 확인과 자동 판독을 강화하는 쪽이다.

backend

윈도우 에러 코드 7번 ‘ERROR_ARENA_TRASHED’는 어디서 왔을까

ERROR_ARENA_TRASHED는 Win32에서 실제로 쓰이는 현대적 에러라기보다 MS-DOS 시절 메모리 관리 구조에서 넘어온 잔재야. MS-DOS가 메모리 블록 앞의 arena 시그니처를 훑다가 예상한 값이 아니면 ‘arena가 망가졌다’고 보고 이 에러를 냈다는 이야기야.

backend

C/C++ 컴파일러의 느슨한 메모리 동시성 버그를 자동으로 잡는 박사논문

C와 C++ 컴파일러에서 relaxed memory 동시성 버그를 찾는 자동 테스트 프레임워크를 다룬 박사논문이 공개됐어. Téléchat, Atomic-mixer 같은 도구로 소스 수준 동작과 컴파일된 프로그램 동작을 비교하고, LLVM과 GCC 툴체인에서 실제 버그를 찾아낸 내용이 핵심이야.