国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

詳解如何在Node.js的httpServer中接收前端發(fā)送的arraybuffer數(shù)據(jù)

2024-05-06 15:28:04
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

最近使用了protobuf進(jìn)行數(shù)據(jù)交互,發(fā)送在node.js接收前端的二進(jìn)制數(shù)據(jù)出現(xiàn)了數(shù)據(jù)錯(cuò)誤等問(wèn)題。后來(lái)發(fā)現(xiàn)思路上面的問(wèn)題,在req.on('data',()=>{})事件中的處理不適當(dāng)才引發(fā)數(shù)據(jù)錯(cuò)亂。借此發(fā)

我先直接貼正確接收二進(jìn)制數(shù)據(jù)代碼

const server = http.createServer((req, res) => {    if(req.method==='OPTIONS'){      res.setHeader("Access-Control-Allow-Origin", "*");      res.statusCode=200;    }    if(req.method==='POST'){     // 存儲(chǔ)數(shù)組空間     let msg=[];     // 接收到數(shù)據(jù)消息     req.on('data',(chunk)=>{      if(chunk){       msg.push(chunk);      }     })     // 接收完畢     req.on('end',()=>{      // 對(duì)buffer數(shù)組陣列列表進(jìn)行buffer合并返回一個(gè)Buffer      let buf=Buffer.concat(msg);      conosole.log(buf)//提取Buffer正確     })         }  });server.listen(3000,'127.0.0.1');

在nodejs中接收buffer數(shù)據(jù)需要以數(shù)組陣列的方式存儲(chǔ)然后通過(guò)buffer.concat對(duì)數(shù)組陣列合并創(chuàng)建新的arraybuffer。這樣就正確的接收二進(jìn)制數(shù)據(jù)了。

示例二:

以后端傳送threejs中的點(diǎn)陣數(shù)組為例:

后端:

let buffer = Buffer.alloc((points.length + 4) * 4)//points.length + 4:預(yù)留前四個(gè)數(shù)字為其他信息(比如兩個(gè)數(shù)字為一組,或者三個(gè)數(shù)字為一組) //預(yù)留位置buffer.writeFloatLE(1, 0)buffer.writeFloatLE(2, 4)buffer.writeFloatLE(3, 8)buffer.writeFloatLE(4, 12)//buffer前四個(gè)數(shù)為信息//point數(shù)據(jù)從第16位開(kāi)始寫入for (let i = 0, len = points.length; i < len; i++) {  buffer.writeFloatLE(points[i], i * 4 + 16)}res.send(buffer)

前端:

let pointXhr = new XMLHttpRequest()pointXhr.onreadystatechange = function () {  var DONE = pointXhr.DONE || 4;  if (pointXhr.readyState === DONE) {    let buffer = pointXhr.response    let bufferArray = new Float32Array(buffer);    for (var i = 0; i < buffer.length; ++i) {      bufferArray[i] = buffer[i];    }    let pointsArray = bufferArray.slice(4)    let points = []    //pointsArray 點(diǎn)陣從第5個(gè)開(kāi)始(前四個(gè)數(shù)為其他信息)    for (let i = 0, l = pointsArray.length / 3; i < l; i++) {      points.push({        x: pointsArray[i * 3],        y: pointsArray[i * 3 + 1],        z: pointsArray[i * 3 + 2]      })    }    callback(points)  }}pointXhr.open("POST",url,true);pointXhr.responseType = 'arraybuffer';pointXhr.send(null);

前端接收?qǐng)D片buffer

let imageXhr = new XMLHttpRequest()imageXhr.onreadystatechange = function () {  var DONE = imageXhr.DONE || 4;  if (imageXhr.readyState === DONE) {    if (imageXhr.response) {      let bufferArray = imageXhr.response      let uint8Array = new Uint8Array(bufferArray);      for (var i = 0; i < bufferArray.length; ++i) {      uint8Array[i] = bufferArray[i];    }    callback(uint8Array)    }  }}imageXhr.open("POST",url,true);imageXhr.responseType = 'arraybuffer';imageXhr.send(null);            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 平塘县| 镇沅| 蒲江县| 方正县| 金溪县| 工布江达县| 呼玛县| 郓城县| 宁波市| 南皮县| 新化县| 信宜市| 南康市| 玉环县| 凭祥市| 木里| 汉沽区| 长葛市| 加查县| 沭阳县| 阳原县| 达日县| 麦盖提县| 大名县| 吉木乃县| 桃江县| 濉溪县| 雅安市| 乐昌市| 扬州市| 阿拉尔市| 明光市| 阳新县| 中江县| 津南区| 兰坪| 永福县| 乌鲁木齐县| 昌黎县| 巴马| 开远市|