解决node里的中文字符编码乱码问题




主要是 iconv-lite 插件,然后把数据流处理成buffer对象,拼接起来,最后在通过 iconv-lite 转码
注意转码用GBK 就可以搞成中文了,下面的转载文章 参考一下。 主要是里面的方法二.







nodejs文件读取中文乱码问题

参考自《深入浅出nodejs》

Buffer对象类似于数组,元素为16进制的两位数,0-255的数值 是二进制,与字符串有编码的关系

Buffer对象可以与字符串之间相互转换,目前支持:ASCII,UTF-8,UTF-16LE/UCS-2,Base64,Binary,Hex

转为buffer: new Buffer(str,[encoding])

转为字符串:buf.toString([encoding],[start],[end])

乱码发生在buffer的拼接

var fs=require('fs');
var rs=fs.createReadStream('test.md');
var data='';
rs.on('data',function(trunk){
    data+=trunk;
})
rs.on('end',function(){
    console.log(data);
})
其实data+=trunk 相当于 data=data.toString()+trunk.toString();

解决方法一:

可读流设置编码readable.setEncoding(encoding);

var rs=fs.createReadStream('test.md');
rs.setEncoding('utf8');
解决方法二:

把多个小buffer拼接成一个大Buffer

var chunks=[];
var size=0;
res.on('data',function(chunk){
    chunks.push(chunk);
    size+=chunk.length;
});
res.on('end',function(){
    var buf=Buffer.concat(chunks,size);
    var str=iconv.decode(buf,'utf8');
    console.log(str);
});
使用Buffer进行文件读取和网络传输,性能比直接纯字符串将近快一倍


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值