获取内网IP地址

工作中遇到一个需求,要求根据不同场地的IP地址,显示相应的大屏页面。

  1. 首先要配置一下Chrome浏览器
    1)在Chrome浏览器中输入:chrome://flags/
    2)搜索 #enable-webrtc-hide-local-ips-with-mdns 该配置 并将属性改为disabled;
    3)点击relaunch 浏览器即可查看到本机的内网IP地址。
  2. 代码部分
const  getIPs =(callback) => {
  var ip_dups = {};
  //compatibility for firefox and chrome
  var RTCPeerConnection =
    window.RTCPeerConnection ||
    window.mozRTCPeerConnection ||
    window.webkitRTCPeerConnection;
  var useWebKit = !!window.webkitRTCPeerConnection;
  //bypass naive webrtc blocking
  if (!RTCPeerConnection) {
    //create an iframe node
    var iframe = document.createElement("iframe");
    iframe.style.display = "none";
    //invalidate content script
    iframe.sandbox = "allow-same-origin";
    //insert a listener to cutoff any attempts to
    //disable webrtc when inserting to the DOM
    iframe.addEventListener(
      "DOMNodeInserted",
      function (e) {
        e.stopPropagation();
      },
      false
    );
    iframe.addEventListener(
      "DOMNodeInsertedIntoDocument",
      function (e) {
        e.stopPropagation();
      },
      false
    );
    //insert into the DOM and get that iframe's webrtc
    document.body.appendChild(iframe);
    var win = iframe.contentWindow;
    RTCPeerConnection =
      win.RTCPeerConnection ||
      win.mozRTCPeerConnection ||
      win.webkitRTCPeerConnection;
    useWebKit = !!win.webkitRTCPeerConnection;
  }
  //minimal requirements for data connection
  var mediaConstraints = {
    optional: [{ RtpDataChannels: true }],
  };
  //firefox already has a default stun server in about:config
  //    media.peerconnection.default_iceservers =
  //    [{"url": "stun:stun.services.mozilla.com"}]
  var servers = undefined;
  //add same stun server for chrome
  if (useWebKit)
    servers = { iceServers: [{ urls: "stun:stun.services.mozilla.com" }] };
  //construct a new RTCPeerConnection
  var pc = new RTCPeerConnection(servers, mediaConstraints);
  function handleCandidate(candidate) {
    //match just the IP address
    var ip_regex = /([0-9]{1,3}(\.[0-9]{1,3}){3})/;
    var ip_addr = ip_regex.exec(candidate)[1];
    //remove duplicates
    if (ip_dups[ip_addr] === undefined) callback(ip_addr);
    ip_dups[ip_addr] = true;
  }
  //listen for candidate events
  pc.onicecandidate = function (ice) {
    //skip non-candidate events
    if (ice.candidate) handleCandidate(ice.candidate.candidate);
  };
  //create a bogus data channel
  pc.createDataChannel("");
  //create an offer sdp
  pc.createOffer(
    function (result) {
      //trigger the stun server request
      pc.setLocalDescription(
        result,
        function () {},
        function () {}
      );
    },
    function () {}
  );
  //wait for a while to let everything done
  setTimeout(function () {
    //read candidate info from local description
    var lines = pc.localDescription.sdp.split("\n");
    lines.forEach(function (line) {
      if (line.indexOf("a=candidate:") === 0) handleCandidate(line);
    });
  }, 1000);
}
export default getIPs;

然后去在使用的位置调用这个方法。

 getIPs(function(ip){
      console.log("获取的内网IP为::", ip);
        let params = { ip: ip };
 }

搜索了很长时间,获取内网地址目前就找到了这一个方法,至少获取公网地址要简单点,有现成的开发好的接口可以使用。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值