node utf8漢字亂碼的解決方法:1、透過「typeof」查看「SarchName」的型別;2、使用「Name=iconv.decode(name,'gbk')」方式轉換編碼為utf8即可。
本教學操作環境:Windows10系統、node v14.16.0版、DELL G3電腦
node utf8漢字亂碼怎麼辦?
node.js實作編碼轉GBK轉UTF8,中文亂碼方案
在做這些之前遇見了一個需求,則是用node去做一個姓名的模糊查詢。其實這是一個簡單再也不能簡單的事情,但卻在這個問題上卡了兩天。
因為業務需要,給新功能做一個模糊查詢。
首先,我得搭建了一個node的http服務,然後我設定了mysql。建立了ORM模型後,準備開始寫sql語句的時候遇見了一個奇怪的事情,由於我的node是utf8的編碼。但是我們公司的資料庫採用的是GBK的編碼,因此導致我在進行資料查詢的時候出現了錯誤,查詢失敗,原因就是因為編碼問題導致。
這問題也很簡單,轉碼嗆! ! !
開始百度node的轉碼方法在這裡就遇見了iconv-jschardet這個插件,於是去npm了一下。開始使用
const iconv = require('iconv-jschardet'); SarchName = iconv.encode(SarchName, 'gbk');
把前端送上來的字元轉成GBK的編碼,很開心。
結果還是報錯了。因為這個錯誤,我找了一整個下午。我也不知道轉成功了沒有,於是試了無數種辦法還是無法解決這個編碼問題,於是想到了之前在寫PHP的時候查詢的時候用SQL轉成二進制進行模糊匹配。
於是我typeof了一下SarchName居然是Obj我就很納悶了應該是String於是輸出印了一下,一看是個Buffer。這下明白了原來沒有直接轉成String那好,我就用Buffer.toString()方法結果還是不行,然後翻了一下文件。發現沒有GBK的編碼,這下就頭大了。
然後我試了試ascii發現還是不行,於是我試了一下binary結果ok了。
**模糊查詢執行完成沒問題了,在傳回的資料的時候發現都還是GBK編碼。那簡單啊! ! ! !那就轉成utf8
Name=iconv.decode(name,'gbk')
然後返回發現沒問題,那ok完成了。
沒過一會兒別人就測出bug說人的名字沒有顯示完全! ! ! !
結果有的人的名字出現了這個符號�。 。 。 。 。
百度發現說解碼不全,暫無任何解決方法。 。 。
最後沒辦法只能用了indexOf('�')方法去檢索字串中出現生僻字
然後記錄其狀態再用PHP進行轉碼。
總之一個字,坑! **
補充:node.js的gbk轉utf8 遇見一些生僻字還是會轉不出來出現亂碼,建議有gbk的庫別讓node去做中文轉碼之類的事情,換別的語言吧。
推薦學習:《node.js影片教學》
以上是node utf8漢字亂碼怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!