> 백엔드 개발 > PHP 튜토리얼 > UTF-8 파일에서 BOM(바이트 순서 표시)을 제거하는 방법은 무엇입니까?

UTF-8 파일에서 BOM(바이트 순서 표시)을 제거하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-17 10:28:24
원래의
944명이 탐색했습니다.

How to Remove Byte Order Marks (BOMs) from a UTF-8 File?

파일 시작 부분에서 BOM(바이트 순서 표시)을 제거하는 방법

문제:

로 표시되는 보이지 않는 문자가 포함된 CSS 파일에 문제가 발생합니다. PHP로 읽을 때 적절한 기능이 중단됩니다. 파일은 UTF-8 인코딩으로 저장되지만 문자를 수동으로 제거하는 것은 어렵습니다.

답변:

관찰되는 문자는 바이트 순서 표시( BOM). BOM은 파일의 바이트 순서(엔디안)를 나타내는 유니코드 문자입니다. 이 경우 UTF-8 BOM은 파일이 UTF-8 인코딩을 사용함을 나타냅니다.

해결책:

  • Editor에서 BOM을 비활성화합니다. 파일을 저장할 때 BOM을 삽입하지 않도록 편집기를 구성하세요. 일부 편집기에서는 "BOM"과 관련된 설정을 찾을 수 있습니다.
  • awk를 사용하여 BOM 제거: awk 명령줄 유틸리티를 사용하여 파일에서 BOM을 제거합니다.
awk 'sub(/^\xEF\xBB\xBF/, "")' input.css > output.css
로그인 후 복사
  • BOM 처리 PHP: 파일을 읽을 때 BOM을 무시하려면 PHP 내부 인코딩을 UTF-8로 설정하세요.
<?php
mb_internal_encoding('UTF-8');
// Read and process CSS files
mb_internal_encoding('previous encoding'); // Restore previous encoding
?>
로그인 후 복사

참고:

  • ISO-8859-15 인코딩은 UTF-8 BOM을 나타낼 수 없으므로 해당 형식으로 파일을 저장하면 데이터가 생성됩니다. 손실.
  • 줄 끝(Windows 및 Linux)은 BOM 감지에 영향을 주어서는 안 됩니다.

위 내용은 UTF-8 파일에서 BOM(바이트 순서 표시)을 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿