Cette fois je vais vous apporter un résumé des méthodes d'exploitation des données binaires en JS Quelles sont les précautions pour l'exploitation des données binaires en JS Voici des cas pratiques, jetons un coup d'œil.
J'ai récemment réalisé plusieurs projets, utilisant js pour manipuler des données binaires et les transmettre via des sockets et en arrière-plan. Utilisez le blog pour l'enregistrer ici
Créez d'abord une nouvelle socket :
1 | var socket= new WebSocket( "ws://192.168.0.147" );
|
Copier après la connexion
Définissez ensuite la fonction à exécuter une fois le socket ouvert et connecté :
Websocket a un attribut binaireType, qui peut être défini sur "blob" ou "arraybuffer". Le format par défaut est "blob". J'ai oublié de le définir sur "arraybuffer" lorsque je travaillais sur le projet. pour utiliser l'objet Blob lors de la réception des données ci-dessous.
1 2 3 4 | socket.onopen= function (){
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]
}
|
Copier après la connexion
Ce qui suit est converti en bype et envoyé :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | var loginBuffer= new ArrayBuffer(30);
var loginDataview= new DataView(loginBuffer);
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);
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;
}
|
Copier après la connexion
Le processus d'envoi ressemble à ceci. Tout d'abord, créez un nouvel objet ArrayBuffer, qui doit remplir le paramètre de longueur du tampon. Pour plus de détails, consultez https://msdn.microsoft.com. /zh-cn/library /br212474(v=vs.94).aspx,
Créez ensuite un nouvel objet DataView et transmettez-y l'ArrayBuffer. Utilisez ensuite les méthodes setUint et getUint de DataView pour lire et définir les bits. Pour plus de détails, reportez-vous à api==> https://msdn.microsoft.com/zh-cn/library/br212463(v=vs.94).aspx
Voici le traitement des données de réception :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | socket.onmessage= function (data){
var blob_= new Blob([data.data]);
parseBlob(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);
var socketConType=dataview_.getUint8(1);
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;
});
})
}
|
Copier après la connexion
Après l'avoir converti en chaîne, vous pouvez faire ce que vous voulez.
Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !
Lecture recommandée :
Quels sont les conseils pour le développement de composants Vue
@HostBinding() et @HostListener() dans AngularJS La différence d'utilisation
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!