イントラネット IP アドレスを取得する

私の仕事では、さまざまな会場の IP アドレスに従って、対応する大画面ページを表示する必要があるという要件に遭遇しました。

  1. まず Chrome ブラウザを設定します
    1) Chrome ブラウザに「chrome://flags/」と入力します
    2) #enable-webrtc-hide-local-ips-with-mdns を検索し、プロパティを無効に変更します;
    3) ブラウザを再起動しますマシンの内部ネットワーク 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 };
 }

長い間探した結果、イントラネット アドレスを取得するこの方法を見つけました。少なくともパブリック ネットワーク アドレスを取得する方が簡単で、既製の開発されたインターフェイスが使用できるようになりました。

おすすめ

転載: blog.csdn.net/qq_44482048/article/details/131653024