有關UTF-8 編碼中BOM的檢測與刪除

來源:互聯網
上載者:User
  1. Shell: #!/bin/sh: No such file or directory
  2. PHP: Warning: Cannot modify header information – headers already sent
複製代碼

在詳細討論UTF-8編碼中BOM的檢測與刪除問題前,不妨先通過一個例子熱熱身:

  1. shell> curl -s http://phone.jbxue.com/ | head -1 | sed -n l
  2. \357\273\277//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">\r$
複製代碼

如上所示,前三個位元組分別是357、273、277,這就是八進位的BOM。

  1. shell> curl -s http://phone.jbxue.com/ | head -1 | hexdump -C
  2. 00000000 ef bb bf 3c 21 44 4f 43 54 59 50 45 20 68 74 6d |...00000010 6c 20 50 55 42 4c 49 43 20 22 2d 2f 2f 57 33 43 |l PUBLIC "-//W3C|
  3. 00000020 2f 2f 44 54 44 20 58 48 54 4d 4c 20 31 2e 30 20 |//DTD XHTML 1.0 |
  4. 00000030 54 72 61 6e 73 69 74 69 6f 6e 61 6c 2f 2f 45 4e |Transitional//EN|
  5. 00000040 22 20 22 68 74 74 70 3a 2f 2f 77 77 77 2e 77 33 |" "http://www.w3|
  6. 00000050 2e 6f 72 67 2f 54 52 2f 78 68 74 6d 6c 31 2f 44 |.org/TR/xhtml1/D|
  7. 00000060 54 44 2f 78 68 74 6d 6c 31 2d 74 72 61 6e 73 69 |TD/xhtml1-transi|
  8. 00000070 74 69 6f 6e 61 6c 2e 64 74 64 22 3e 0d 0a |tional.dtd">..|
複製代碼

如上所示,前三個位元組分別是EF、BB、BF,這就是十六進位的BOM。

註:用到了第三方網站的頁面,不能保證例子始終可用。

實際做項目開發時,可能會面對成百上千個文字檔,如果有幾個檔案混入了BOM,那麼很難察覺,如果沒有帶BOM的UTF-8文字檔例子,可以用vi杜撰幾個,相關命令如下: #設定UTF-8編碼 :set fileencoding=utf-8 #添加BOM :set bomb #刪除BOM :set nobomb #查詢BOM :set bomb?

檢測UTF-8編碼中的BOM

  1. shell> grep -r -I -l $'^\xEF\xBB\xBF' /path
複製代碼

刪除UTF-8編碼中的BOM

  1. shell> grep -r -I -l $'^\xEF\xBB\xBF' /path | xargs sed -i 's/^\xEF\xBB\xBF//;q'
複製代碼

推薦:如果使用SVN,可以在pre-commit鉤子裡加上相關代碼用以杜絕BOM。

  1. #!/bin/sh

  2. REPOS="$1"

  3. TXN="$2"

  4. SVNLOOK=/usr/bin/svnlook

  5. FILES=`$SVNLOOK changed -t "$TXN" "$REPOS" | awk '/^[UA]/ {print $2}'`

  6. for FILE in $FILES; do

  7. if $SVNLOOK cat -t "$TXN" "$REPOS" "$FILE" | grep -q $'^\xEF\xBB\xBF'; then
  8. echo "Byte Order Mark be found in $FILE" 1>&2
  9. exit 1
  10. fi
  11. done

複製代碼您可能感興趣的文章:php執行個體:檢測並清除檔案開頭的BOM資訊Php批量去除bom頭資訊的實現代碼php去掉bom頭的代碼分享PHP 過濾頁面中的BOM資料的簡單一實例檢測php檔案是否有bom頭的代碼批量清除php檔案中bom的方法檢查並清除php檔案中bom的函數有關 UTF-8 BOM 導致樣式錯亂的解決方案BOM與DOM的區別分析
  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.