侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

NodeJs 模仿SIP话机注册的方法

前端  /  管理员 发布于 5年前   458

本项目需要对应的后端接口、信令环境才能正常运行,本文章只涉及前端内容。

项目依赖模块:

  • NodeJs
  • readline:命令行输入
  • ws:与服务端建立websocket连接
  • superagent:与服务端建立请求连接,效果类似ajax请求
  • tsk_md5:项目登录密码使用MD5加密

项目需求

模拟SIP话机频繁向服务器发起注册请求,以得到服务器最大SIP注册数

项目实现概述

  1. 终端输入连续注册分机的开始分机号和结束分机号
  2. 终端输入统一的SIP注册密码
  3. 终端输入服务器地址
  4. 先进行用户登录鉴权,用户登录鉴权通过后再发起SIP注册

代码分析

1. 引入项目所需模块

var WebSocket = require('ws'), superagent = require('superagent'), tskMD5 = require('./tsk_md5') const readline = require('readline');

2. 创建readline 接口实例

const rl = readline.createInterface({    input: process.stdin,    output: process.stdout,    prompt: 'OHAI> ' });

3. 定义所需变量

var obj = {}, httpHeader = {}, baseUrl ='', pass = '', ip = '', websocketUrl = ''var keepWsAlive, readyState

4. 读取readline 输入信息函数

function getReadline() { const lines = []; // 用于保存所有输入信息。 console.log('Please input the range of extensions(eg: 1001,1010):\n') rl.on("line", function(line) {  if (line ==='') {   console.log('The input is empty, please input again:\n')  } else {   lines.push(line);   if (lines.length === 1) {    obj.extensionsArr = line.split(',');    console.log('Please input the password(eg:1234aa):\n')   } else if (lines.length === 2) {    obj.password = line;    pass = line;    console.log('Please input the ip(eg:192.168.124.125):\n')   } else if (lines.length === 3) {    websocketUrl = 'ws://' + line + ':8089/ws';    obj.websocketUrl = websocketUrl;    obj.ip = line;    ip = line;    console.log('Starting register...\n');    // 开始注册事件    loopRegister(obj)    }  } });  // close事件监听 rl.on("close", function(){  // 结束程序  process.exit(0); }); }

终端运行截图

 

5.注册事件中包含几个动作

1)设置httpHeader:浏览器与服务器ajax请求有固定的请求头信息,此处模拟浏览器的请求头信息。

用于后续发送请求进行用户登录鉴权。

function setHttpHeader(username) {  httpHeader = {   Accept:'application/json, text/javascript, */*; q=0.01',   'Accept-Encoding': 'gzip, deflate',   'Accept-Language': 'zh-CN,zh;q=0.9,en;q=0.8,pt;q=0.7',   'Cache-Control': 'no-cache',   Connection: 'keep-alive',   'Content-Type': 'application/x-www-form-urlencoded; ',   Cookie: 'TRACKID='+trackid+'; session-identify=sid121076289-1520217430; username=admin; user_id=0',   Host: ip +':8089',   Origin: 'http://'+ip+':8089',   Pragma: 'no-cache',   Referer: 'http://'+ip+':8089/gswave/',   'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/38.0.2125.122 Safari/537.36 SE 2.X MetaSr 1.0',   'X-Requested-With':'XMLHttpRequest'  }  var accountData = {   action:'challenge',   user:username  }  baseUrl = 'http://'+ip+':8089/webrtccgi?';  getChanllenge(accountData, username) // 用户鉴权函数 }

2)用户登录鉴权(本项目中与服务器交互需要使用,具体使用看服务器端设置)

function getChanllenge(accountData, username) {  console.log('start getChangllenge')  var challenge = ''  //获取challenge   superagent    .post(baseUrl)    .set(httpHeader)    .type('form')    .send(accountData)    .redirects(0)    .end(function(err, result) {     if (typeof(result) == 'undefined') {      console.error("get challenge is error, result is undefined");     } else {      var responce = result.body      if(responce && responce.status === 0) {       challenge = responce.response.challenge       getCookie(challenge, username)      } else {       console.error('get challenge is error, result.body.status is not 0')      }     }    }); }   function getCookie(challenge, username) {  var md5key = tskMD5.MD5.hexdigest(challenge + pass) // MD5加密用户登录密码  var subData={   token: md5key,   action: 'login',   user: username  }  // 开始请求进行用户登录密码鉴权,类似ajax请求  superagent   .post(baseUrl)   .set(httpHeader)   .type('form')   .send(subData)   .redirects(0)   .end(function(err, res) {    if (typeof(res) == 'undefined') {     console.log("get cookie is error, result is undefined");    } else {     var responce = res.body     if(responce && responce.status === 0) {     // 登录鉴权通过,开始执行SIP注册      var cookie = responce.response.cookie      // 注册函数      startSocket(username)     } else {      console.log('get cookie is error, result.body.status is not 0')     }    }   }) }

与服务器建立websocket连接

项目中信令交互信息均通过websocket发送

var ws = new WebSocket(websocketUrl, "sip"); # 注意建立的是sip类型的websocket ws.on('open', function open() {  console.log('ws open message1' + message1)  readyState = WebSocket.OPEN  // 发送相关信息  ws.send(message);  });  ws.on('message', function incoming(data) {  a++;  var dataArr = data.split('\r\n')  if (dataArr[0].indexOf('401') > -1 && a === 1) {   // 发送注册信令函数(其中发送信令信息,均参考浏览器的发送头进行拼接)   startRegister(ws, dataArr, username)  } else if (dataArr[0].indexOf('200')) {   // ws.close()   // console.log('register sucess...')  } else {  } });

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

您可能感兴趣的文章:

  • nodejs实现获取本地文件夹下图片信息功能示例
  • 配置node服务器并且链接微信公众号接口配置步骤详解
  • 三分钟教你用Node做一个微信哄女友(基友)神器(面向小白)
  • 什么时候不能在 Node.js 中使用 Lock Files


  • 上一条:
    基于jQuery的时间戳与日期间的转化
    下一条:
    Vue多环境代理配置方法思路详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客