node.js express环境下中文须要注意的地方

问题一:express

最近在nuxt项目中开始着手把一些跨域的请求转移到express里,其实跟其余语言差很少,http对象发请求,接收请求都写得很顺畅。以前用的请求部分大多数是get请求,因此除了注意编码问题以外,就基本上接口什么写得很快,可是POST请求里因为要计算Content-Length,这里就出现一个因为中文计算长度有问题致使的请求失败。json

  var bodyString = JSON.stringify(obj)
var options = { method: 'POST', host: 'mt.emoney.cn', port: 80, path: `*********`, headers: { 'Content-Type': 'application/json;charset=utf-8', 'Content-Length': bodyString.length } }

上面这样发起请求时,若是obj对象里面有属性里面包含了中文,bodyString.length就计算有问题,如下标红的是一种方案。跨域

  var bodyString = JSON.stringify(obj)
bodyString = new Buffer(bodyString) var options = { method: 'POST', host: 'mt.emoney.cn', port: 80, path: `/platform/stock/MarkStock`, headers: { 'Content-Type': 'application/json;charset=utf-8', 'Content-Length': bodyString.length } }

这里还有另外一种获取长度的方案。app

Buffer.byteLength(data, 'utf8');

 问题二:编码

基本上我在网上找了一段获取请求内容并输出的代码是这样的,options部分先省略
spa

  var cusRequest = http.request(options, back => {
    if (back.statusCode === 200) {
      var body = ''
      back.on('data', data => {
        body += data
      }).on('end', () => {
        res.status(200).send(body)
      })
    } else {
      res.status(500).send('error')
    }
  })
  cusRequest.end()

用body进行字符串的拼接,这里的data我输出来看了一下,是个Buffer数据,由于是一段一段的,它默认先转换为字符串拼接到body后面,可是中文可能有点不太同样,一旦中间的某个中文字符串恰好被先后两个data截断,那么就会出现一大段中文中某几个字变成乱码,因此这里不能用字符串进行拼接,得直接用Buffer拼接好后在进行转换为中文。以下面代码所示:nuxt

 var cusRequest = http.request(options, back => {
    if (back.statusCode === 200) {
      var bufs = [] back.on('data', data => { bufs.push(data) }).on('end', () => { var buf = Buffer.concat(bufs)
        res.status(200).send(buf.toString())
      })
    } else {
      res.status(500).send('error')
    }
  })
  cusRequest.end()
相关文章
相关标签/搜索