ホームページ  >  記事  >  ウェブフロントエンド  >  jsはバイナリデータを操作するメソッドを実装します

jsはバイナリデータを操作するメソッドを実装します

亚连
亚连オリジナル
2018-06-01 16:27:511968ブラウズ

ここで、バイナリデータを操作するための js メソッドを共有します。これは良い参考値なので、皆さんのお役に立てれば幸いです。

私は最近、js を使用してバイナリ データを操作し、ソケットとバックグラウンドを介して送信するいくつかのプロジェクトを実行しました。ここでブログのメモをさせてください

まず、新しいソケットを作成します:

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

次に、ソケットが開かれて接続された後に実行される関数を定義します:

websocket には属性 binaryType があり、これを設定できます「blob」または「arraybuffer」に設定すると、デフォルトの形式は「blob」になります。プロジェクトを実行するときに「arraybuffer」に設定するのを忘れたので、以下のデータを受け取るには Blob オブジェクトを使用する必要があります。

socket.onopen=function(){
 //发送登录帧,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]        
}

以下は bype に変換されて送信されます:

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;
}

送信プロセスは大まかに次のようになります。まず、新しい ArrayBuffer オブジェクトを作成します。詳細については、API を確認してください。 ==> https://msdn .microsoft.com/zh-cn/library/br212474(v=vs.94).aspx,

次に、新しい DataView オブジェクトを作成し、そこに ArrayBuffer を渡します。次に、DataView の setUint メソッドと getUint メソッドを使用してビットを読み取り、設定します。詳細については、api==> https://msdn.microsoft.com/zh-cn/library/br212463(v=vs.94).aspx

を参照してください。 以下はデータ受信の処理です:

//接收消息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) === &#39;function&#39;) {
    cb.call(r,r.result);
    }
  }
  try{
    r[&#39;readAs&#39;+type](blob);
  }catch(e){}
  }
}
function parseBlob(blob){
 reader.readAs(&#39;ArrayBuffer&#39;,blob.slice(0,blob.size),function(arr){
   var dataview_=new DataView(arr);
   //协议中第二位是判断数据来源的
   var socketConType=dataview_.getUint8(1);
   //转成字符串读取数据
   var modulelength=(dataview_.buffer.byteLength-46)/33;
   var modulestate={};
    reader.readAs(&#39;Text&#39;,blob.slice(i*33+37,i*33+37+32),function(result){
    modulestate[dataview_.getUint8(i*33+36)]=result;
   });
 })
}

以上が皆様の参考になれば幸いです。

関連記事:

webpackソースコードのローダーメカニズムの詳細な説明

react reduxミドルウェアの使い方の簡単な紹介

js+cssを使用してタイピング効果を実現

以上がjsはバイナリデータを操作するメソッドを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。