php中json_encode格式中文問題解決方案_PHP教程

來源:互聯網
上載者:User
  1. 原因分析:

  在儲存到資料庫時!MySQL 不會儲存 unicode 字元:

  MySQL 僅支援從基本的多語種平面字元 (0×0000-0xFFFF)。請嘗試儲存一個同義字相反:)

  更新: MySQL 5.5.3 上 (其中尚未 GA), 支援補充字元如果您使用 UTF8MB4 編碼。

  json_encode中文的時候,會把每個中文字元encode成“uxxxx”

  而存進資料庫的時候,“”被屏蔽了,直接變成”uxxxx”

  2. 解決問題:

  知道是什麼原因就好解決問題了,你可以選擇其他儲存方式;

  或者再對症下藥進一步轉義””為“”,以保留””

  我們的解決方案:

  1. 避免json_encode將中文轉換unicode編碼.

  PHP5.4版本,已經給Json新增了一個選項: JSON_UNESCAPED_UNICODE。加上這個選項後,就不會自動把中文編碼了。

  $test = json_encode("深圳", JSON_UNESCAPED_UNICODE);

  2. 先將中文欄位urlencode,json_encode後,再用urldecode,也可以保證中文不會被轉成unicode。

  $test =urldecode(json_encode(array('brief'=>urlencode('簡介'),'title'=>urlencode(標題)));

  3. 進一步轉義””為“” 避免unicode中文前’'被mysql當成特殊字元去除

http://www.bkjia.com/PHPjc/371391.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/371391.htmlTechArticle1. 原因分析: 在儲存到資料庫時!MySQL 不會儲存 unicode 字元: MySQL 僅支援從基本的多語種平面字元 (00000-0xFFFF)。請嘗試儲存一個同義字相反...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.