微信小程序用udp协议与服务器通信(一):连接服务器,将数据传输给服务器

在微信小程序中udp通信传送的message支持两种格式: ArrayBuffer和string,可按服务器要接受的格式传送

ArrayBuffer格式传送

要使用ArrayBuffer格式传送,就需要将String转化为ArrayBuffer,这里我在util.js写了一个函数作为转化工具


    //字符串内容转arrayBuffer
    function stringToArrayBuffer (str) {
      var bytes = new Array(); 
      var len,c;
      len = str.length;
      for(var i = 0; i < len; i++){
        c = str.charCodeAt(i);
        if(c >= 0x010000 && c <= 0x10FFFF){
          bytes.push(((c >> 18) & 0x07) | 0xF0);
          bytes.push(((c >> 12) & 0x3F) | 0x80);
          bytes.push(((c >> 6) & 0x3F) | 0x80);
          bytes.push((c & 0x3F) | 0x80);
        }else if(c >= 0x000800 && c <= 0x00FFFF){
          bytes.push(((c >> 12) & 0x0F) | 0xE0);
          bytes.push(((c >> 6) & 0x3F) | 0x80);
          bytes.push((c & 0x3F) | 0x80);
        }else if(c >= 0x000080 && c <= 0x0007FF){
          bytes.push(((c >> 6) & 0x1F) | 0xC0);
          bytes.push((c & 0x3F) | 0x80);
        }else{
          bytes.push(c & 0xFF);
        }
      }
      var array = new Int8Array(bytes.length+10);//10个字节的包头+包长+版本号
      //4个字节表示包头(以下包头填自己的udp协议包头,用十六进制对应的十进制表示,如ef用239)
      array[0]=239;
      array[1]=xxx;
      array[2]=xxx;
      array[3]=xxx;
      //包长(填自己包长的计算方法,我这里是2个字节版本号+内容字节长度)
      var leng=2+bytes.length;
      console.log('leng='+leng)

if(leng<=255){
  array[4]=leng;
      array[5]=0;
      array[6]=0;
      array[7]=0;
}else{
  array[4]=leng%256;
  array[5]=parseInt(leng/256);
  array[6]=0;
  array[7]=0;
}
      //版本号
      array[8]=0;
      array[9]=1;
      //内容
      for(var i=0 ;i<=bytes.length;i++){
        array[i+10] =bytes[i];
      }
      return array.buffer;
    }

// ArrayBuffer转Str
function ArrayBufferToStr(value) {

  //取去掉10个字节包头后的数据
  var buffer = value.slice(10)

  var dataview = new DataView(buffer)
  var ints = new Uint8Array(buffer.byteLength)
  var str = ''
  for (var i = 0; i < ints.length; i++) {
  str += String.fromCharCode(dataview.getUint8(i)) 
  }
  return str
  
  }

//没有加包头的转换
// function stringToArrayBuffer(str) {
// 	var bytes = new Array(); 
// 	var len,c;
// 	len = str.length;
// 	for(var i = 0; i < len; i++){
// 		c = str.charCodeAt(i);
// 		if(c >= 0x010000 && c <= 0x10FFFF){
// 			bytes.push(((c >> 18) & 0x07) | 0xF0);
// 			bytes.push(((c >> 12) & 0x3F) | 0x80);
// 			bytes.push(((c >> 6) & 0x3F) | 0x80);
// 			bytes.push((c & 0x3F) | 0x80);
// 		}else if(c >= 0x000800 && c <= 0x00FFFF){
// 			bytes.push(((c >> 12) & 0x0F) | 0xE0);
// 			bytes.push(((c >> 6) & 0x3F) | 0x80);
// 			bytes.push((c & 0x3F) | 0x80);
// 		}else if(c >= 0x000080 && c <= 0x0007FF){
// 			bytes.push(((c >> 6) & 0x1F) | 0xC0);
// 			bytes.push((c & 0x3F) | 0x80);
// 		}else{
// 			bytes.push(c & 0xFF);
// 		}
//   }
//   var array = new Int8Array(bytes.length);
//   for(var i in bytes){
//     array[i] =bytes[i];
//   }
// 	return array.buffer;
// }

//不写这个,其他的js页面就找不到我们所写的函数
module.exports = {
  ArrayBufferToStr:ArrayBufferToStr,
  stringToArrayBuffer:stringToArrayBuffer
}



此时要在要使用udp通信的js文件中引用utils.js:在该js文件第一行写var util=require('../../utils/util');

//建立套接字
 const udp = wx.createUDPSocket()
    udp.bind()
    udp.send({ 
    //要连接的服务器地址和端口号 
      address:'XXXXXX',
      port: 'XXXX',  
      // ArrayBuffer格式传送   
      message:util.stringToArrayBuffer(
      '"user_name":"'+this.data.user_name+'",'+
      '"user_pwd":"'+this.data.user_pwd+'"}'),
       // string格式传送   
     
    })

用网络调试助手模拟服务器查看收到的数据(要用网络调试助手的地址和端口号)
在这里插入图片描述

String格式传送

string可以直接传送

const udp = wx.createUDPSocket()
    udp.bind()
    udp.send({ 
    //要连接的服务器地址和端口号 
      address:'XXXXXX',
      port: 'XXXX',  
   
      message:
      '"user_name":"'+this.data.user_name+'",'+
      '"user_pwd":"'+this.data.user_pwd+'"}',
    })

用网络调试助手模拟服务器查看收到的数据(要用网络调试助手的地址和端口号)
在这里插入图片描述

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值