亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js操作二進制數(shù)據(jù)方法

 更新時間:2018年03月03日 09:31:33   作者:離丶花香  
下面小編就為大家分享一篇js操作二進制數(shù)據(jù)方法,具有很好的參考價值,希望對的大家有所幫助。一起跟隨小編過來看看吧

最近做了幾個項目,用js操作二進制數(shù)據(jù),通過socket與后臺進行傳輸。在此用博客做個記錄

首先是新建一個socket:

var socket=new WebSocket("ws://192.168.0.147");

接著定義socket打開,連接之后執(zhí)行的函數(shù):

websocket有個屬性binaryType,可將其設(shè)置為“blob”或者“arraybuffer”,默認格式為“blob”,做項目的時候忘記設(shè)置為“arraybuffer”了,結(jié)果在下面接收數(shù)據(jù)的時候就需要用Blob對象來接。

socket.onopen=function(){
 //發(fā)送登錄幀,4-20位為手機號
 var loginArr=[0X02,0X02,0X00,0X1E,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X20,0X00,0X00,0X00,0X00,0X00,0X00,0X00,0X00,0X0D,0X0A]        
}

下面是轉(zhuǎn)成bype發(fā)送出去:

var loginBuffer=new ArrayBuffer(30);
var loginDataview=new DataView(loginBuffer);
//localstorageuserinfo為緩存在本地的用戶手機號
var telArr=localstorageuserinfo.TelPhone; 
var loginTime=tempTrans();
for(var i=0;i<loginArr.length;){
 loginDataview.setInt8(i,loginArr[i]);
 if(i>3&&i<(telArr.length+4)){
   loginDataview.setInt8(i,telArr.charCodeAt(i-4));
 }   
 if(i>19&&i<loginArr.length-2){
  loginDataview.setInt8(i,loginTime[i-20]);
 }
 i++;
}
//登錄包
socket.send(loginDataview.buffer);   
//格式化時間同時按照年倆位月日時分秒1位由高到底排序
function tempTrans(time){
 if(!time){
  time=new Date();
 }
 var u32Dataview=new DataView(new Uint16Array([time.getFullYear()]).buffer);
 var uint8=[];
 uint8.push(new DataView(new Uint8Array([0X00]).buffer).getUint8(0))
 for(var i=u32Dataview.byteLength-1;i>=0;i--){
  uint8.push(u32Dataview.getUint8(i))
 }
 uint8.push(new DataView(new Uint8Array([time.getMonth()+1]).buffer).getUint8(0));
 uint8.push(new DataView(new Uint8Array([time.getDate()]).buffer).getUint8(0));
 uint8.push(new DataView(new Uint8Array([time.getHours()]).buffer).getUint8(0));
 uint8.push(new DataView(new Uint8Array([time.getMinutes()]).buffer).getUint8(0));
 uint8.push(new DataView(new Uint8Array([time.getSeconds()]).buffer).getUint8(0));
 return uint8;
}

發(fā)送的流程大概就是這樣,先new ArrayBuffer對象,該對象需要填入緩沖區(qū)長度參數(shù),具體查看api==> https://msdn.microsoft.com/zh-cn/library/br212474(v=vs.94).aspx,

然后新建DataView對象,將ArrayBuffer傳進去。然后用DataView的setUint和getUint方法按位進行讀取設(shè)置,具體參考api==> https://msdn.microsoft.com/zh-cn/library/br212463(v=vs.94).aspx

下面是接收數(shù)據(jù)處理:

//接收消息onmessage
socket.onmessage=function(data){
  var blob_=new Blob([data.data]);
  parseBlob(blob_);
 }
//使用fileReader操作blob對象
var reader = { 
 readAs: function(type,blob,cb){
  var r = new FileReader();
  r.onloadend = function(){
    if(typeof(cb) === 'function') {
    cb.call(r,r.result);
    }
  }
  try{
    r['readAs'+type](blob);
  }catch(e){}
  }
}
function parseBlob(blob){
 reader.readAs('ArrayBuffer',blob.slice(0,blob.size),function(arr){
   var dataview_=new DataView(arr);
   //協(xié)議中第二位是判斷數(shù)據(jù)來源的
   var socketConType=dataview_.getUint8(1);
   //轉(zhuǎn)成字符串讀取數(shù)據(jù)
   var modulelength=(dataview_.buffer.byteLength-46)/33;
   var modulestate={};
    reader.readAs('Text',blob.slice(i*33+37,i*33+37+32),function(result){
    modulestate[dataview_.getUint8(i*33+36)]=result;
   });
 })
}

轉(zhuǎn)成字符串之后就可以為所欲為了。

以上就是我做項目時用到的操作二進制數(shù)據(jù)的方法,按位讀取頭都要炸了······google開源的protobuf能夠設(shè)置完數(shù)據(jù)格式之后,所有讀取操作都不用自己拼接了,非常舒服。不過不懂后臺技術(shù),我只能跟在后臺大佬后面吃饃渣 TnT

這篇js操作二進制數(shù)據(jù)方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論