>웹 프론트엔드 >프런트엔드 Q&A >노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?

노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?

藏色散人
藏色散人원래의
2023-02-08 10:29:122173검색

Node utf8 한자 왜곡 해결 방법: 1. "typeof"를 통해 "SarchName" 유형을 확인합니다. 2. "Name=iconv.decode(name,'gbk')" 메서드를 사용하여 인코딩을 utf8로 변환합니다.

노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?

이 튜토리얼의 운영 환경: Windows 10 시스템, 노드 v14.16.0 버전, DELL G3 컴퓨터

노드 utf8 한자가 깨졌을 경우 어떻게 해야 하나요?

  • node.js는 GBK에서 UTF8로의 인코딩 변환, 중국어 왜곡 솔루션을 구현합니다.

이 작업을 수행하기 전에 node를 사용하여 이름에 대한 퍼지 쿼리를 수행해야 한다는 필요성을 충족했습니다. 사실 이건 더 이상 단순할 수 없는 단순한 문제인데, 이틀 동안 이 문제에 매달렸습니다.

비즈니스 요구로 인해 새 기능에 대한 퍼지 쿼리를 만들었습니다.

먼저 노드 http 서비스를 설정해야했고, 그 다음에는 mysql을 구성했습니다. ORM 모델을 구축한 후 SQL 문을 작성하려고 할 때 이상한 현상이 발생했습니다. 내 노드가 utf8로 인코딩되었기 때문입니다. 그런데 저희 회사의 데이터베이스는 GBK 인코딩을 사용하고 있는데, 데이터 쿼리를 했을 때 오류가 발생했는데, 그 이유는 인코딩 문제 때문이었습니다.

이 문제도 매우 간단합니다. 트랜스코딩만 하면 됩니다! ! !

바이두 노드의 트랜스코딩 방식을 사용하기 시작하다 우연히 iconv-jschardet 플러그인을 발견해서 npm에 가서 확인해 봤습니다.

const iconv = require('iconv-jschardet');
SarchName =  iconv.encode(SarchName, 'gbk');

를 사용하여 프런트 엔드에서 보낸 문자를 GBK 인코딩으로 변환하기 시작했습니다.

결과는 여전히 오류입니다. 이 오류 때문에 찾느라 오후 시간을 보냈습니다. 변환이 성공했는지 모르겠어서 수많은 방법을 시도했지만 여전히 인코딩 문제를 해결하지 못해서, PHP 작성시 쿼리할 때 퍼지 매칭을 위해 SQL을 사용하여 바이너리로 변환하여 퍼지 매칭을 해보자고 생각했습니다.

그래서 SarchName을 입력했는데 Obj로 나오네요. 너무 혼란스러워서 String이어야 한다고 생각해서 인쇄해 보니 Buffer였습니다. 이제 String으로 직접 변환하지 않는 것이 더 낫다는 것을 깨달았습니다. Buffer.toString() 메서드를 사용했지만 여전히 작동하지 않았고 문서를 살펴보았습니다. GBK 인코딩이 없다는 사실을 알게 되었는데, 그게 큰 골칫거리였습니다.

노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?

그러다가 ascii를 사용해 보았는데 여전히 작동하지 않아서 바이너리를 사용해 보았는데 괜찮았습니다.

노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?

** 반환된 데이터를 찾았을 때 여전히 GBK로 인코딩되어 있어 퍼지 쿼리 실행이 문제 없이 완료되었습니다. 그건 쉽습니다! ! ! ! 그런 다음 utf8

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

로 변환한 다음 돌아와서 문제가 없는 것을 확인하면 완료된 것입니다.

잠시 후 다른 분이 버그를 발견해서 이름이 제대로 나오지 않는다고 하더군요! ! ! !

그 결과, 어떤 사람들의 이름에는 � 기호가 나타났습니다. . . . .

Baidu는 디코딩이 불완전하며 현재 해결책이 없음을 발견했습니다. . .

결국 문자열에서 희귀 문자를 검색하기 위해 indexOf('�') 메소드를 사용할 수밖에 없었습니다.

그런 다음 상태를 기록하고 PHP를 사용하여 트랜스코딩했습니다.

한마디로 핏! **

보충 사항: Node.js의 utf8로의 gbk 변환은 여전히 ​​일부 희귀 문자 변환에 실패하고 문자 깨짐을 발생시킵니다. gbk가 있는 라이브러리에서는 노드가 중국어 트랜스코딩과 다른 언어로 변경하는 것을 허용하지 않는 것이 좋습니다.

추천 학습: "node.js 비디오 튜토리얼"

위 내용은 노드 utf8 한자가 깨졌을 경우 어떻게 해야 할까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.