首頁 >web前端 >前端問答 >node utf8漢字亂碼怎麼辦

node utf8漢字亂碼怎麼辦

藏色散人
藏色散人原創
2023-02-08 10:29:122114瀏覽

node utf8漢字亂碼的解決方法:1、透過「typeof」查看「SarchName」的型別;2、使用「Name=iconv.decode(name,'gbk')」方式轉換編碼為utf8即可。

node 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的編碼,這下就頭大了。

node utf8漢字亂碼怎麼辦

然後我試了試ascii發現還是不行,於是我試了一下binary結果ok了。

node utf8漢字亂碼怎麼辦

**模糊查詢執行完成沒問題了,在傳回的資料的時候發現都還是GBK編碼。那簡單啊! ! ! !那就轉成utf8

Name=iconv.decode(name,'gbk')

然後返回發現沒問題,那ok完成了。

沒過一會兒別人就測出bug說人的名字沒有顯示完全! ! ! !

結果有的人的名字出現了這個符號�。 。 。 。 。

百度發現說解碼不全,暫無任何解決方法。 。 。

最後沒辦法只能用了indexOf('�')方法去檢索字串中出現生僻字

然後記錄其狀態再用PHP進行轉碼。

總之一個字,坑! **

補充:node.js的gbk轉utf8 遇見一些生僻字還是會轉不出來出現亂碼,建議有gbk的庫別讓node去做中文轉碼之類的事情,換別的語言吧。

推薦學習:《node.js影片教學

以上是node utf8漢字亂碼怎麼辦的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn