跳到主要內容

網址的中文不是中文,更不是 UTF-8

 

網址的中文不是中文,這個觀念一直是我「網址中不一定要放中文」的核心邏輯,尤其在搜尋引擎中你搜尋的關鍵字跟網址中的中文編碼就不一樣了
中文在各種編碼的呈現
根據 W3C 的定義

URL encoding converts characters into a format that can be transmitted over the Internet. URLs can only be sent over the Internet using the ASCII character-set. Since URLs often contain characters outside the ASCII set, the URL has to be converted into a valid ASCII format. URL encoding replaces unsafe ASCII characters with a "%" followed by two hexadecimal digits. URLs cannot contain spaces. URL encoding normally replaces a space with a plus (+) sign or with %20.[1]

然後最近已經看到多次 SEO 相關文章講到網址的時候說:網址是 UTF-8 的格式。這讓我頭很痛,網址(嚴格來說 URI)的中文不是中文,也不是 UTF-8 編碼 是 UTF-8 編碼(而且還要是 16 進位編碼)過後,再經過 url encoding 的結果[2]

另外 URL encoding 的解碼,是依據「網頁編碼」是什麼還會有所變化,雖然這年頭 big5 跟 unicode 的網頁已經屬於稀世珍物,但如果是「中文」來說,網址的呈現是 

  • UTF-8 的網頁是 %e4%b8%ad%e6%96%87 
  • Big5 的網頁是 %a4%a4%a4%e5 
  • unicode 的網頁是 %u4e2d%u6587 
為什麼要強調 URI (也可以說 URL 啦)呢?因為「網域的中文也不是中文」而那更是另外一種編碼了...

參考資料

  1. https://www.w3schools.com/tags/ref_urlencode.ASP 
  2. https://zh.wikipedia.org/zh-tw/%E7%99%BE%E5%88%86%E5%8F%B7%E7%BC%96%E7%A0%81 

留言

這個網誌中的熱門文章

2022年了, Google 都建議你不要做 sitemap 了:重新認識 SEO 中的 Sitemap

首先,如果我跟你說你的網站 其實可能「不」需要 Sitemap ,我想這句話會顛覆多數人的認知,但實際上這句話卻是 Google 官方文件白紙黑字寫出來的[1],以下是可能「不」需要 Sitemap 的情況: 網站規模很「小」:所謂的規模很「小」,指的是網站的 網頁數不超過 500 個  (以您認為有需要納入搜尋結果的網頁為準)。 網站內部的連結完善:這表示 Google 可以透過首頁的連結找出網站上所有的重要網頁。 要顯示在搜尋結果中的媒體檔案 (影片、圖片) 或新聞網頁數量不多:Sitemap 可協助 Google 在您的網站上找出影片和圖片檔或新聞報導,並加以解讀。如果您不需要讓這些內容出現在圖片、影片或新聞搜尋結果中,可能就不需要 Sitemap。 其實絕大多數各位手邊的網站,真的有需要納入搜尋結果的網頁,各位請自行捫心自問一下:真的有超過 500 頁嗎?如果是電商,你的商品數真的有那麼多嗎?當然這是極端的說法,因為我相信大家都會覺得說:那有一天我超過 500 個怎麼辦,或是我是新網站怎麼辦?

為什麼我的網站排名突然掉了?因為你可能忽略了 Mobile-First

最近有許多朋友紛紛來找我做 SEO ,而且絕大多數都是舊的網站要做 SEO ,而經過我想都不用想馬上打開了 PageSpeed Insight 檢查這些朋友的網站,95% 以上都有共通的問題: Mobile-First 這件事情沒有做好, 讓行動版的排名連帶影響了桌面版的搜尋排名。

PageRank 與 Bing 反向連結認定間的互斥

我們在前一篇 再論PageRank在操作SEO的不重要性 中有稍微提到關於 PageRank 的觀念計算公式(請注意,並非完整公式)。這篇我們再來簡單的理解一下,畢竟PageRank雖然不那麼重要,但畢竟Google還是有說過PageRank目前還是搜尋排名的權重之一(雖然極低,大概比meta description中有沒有出現關鍵字還低),那為什麼Google跟Bing的搜尋結果是有差別的。