首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何使用JavaScript获取内网IP?

如何使用JavaScript获取内网IP?
EN

Stack Overflow用户
提问于 2017-03-22 10:12:25
回答 1查看 1.3K关注 0票数 1

我正在使用我在Github上找到的代码,通过WebRTC获取私有网络的IP地址。

这在Chrome中工作得很好,但是在Firefox中我只能得到响应中的公共IP地址。

有什么办法可以解决这个问题吗?我只针对这些浏览器的最新版本。

代码语言:javascript
运行
复制
            function getIPs(callback){
                var ip_dups = {};

                var RTCPeerConnection = window.RTCPeerConnection
                    || window.mozRTCPeerConnection
                    || window.webkitRTCPeerConnection;

                //bypass naive webrtc blocking using an iframe
                if(!RTCPeerConnection){
                    var win = iframe.contentWindow;
                    RTCPeerConnection = win.RTCPeerConnection
                        || win.mozRTCPeerConnection
                        || win.webkitRTCPeerConnection;
                }

                //minimal requirements for data connection
                var mediaConstraints = {
                    optional: [{RtpDataChannels: true}]
                };

                var servers = {iceServers: [{urls: "stun:stun.l.google.com:19302"}]};

                //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}|[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7})/
                    var ip_addr = ip_regex.exec(candidate)[1];

                    //remove duplicates
                    if(ip_dups[ip_addr] === undefined)
                        callback(ip_addr);

                    ip_dups[ip_addr] = true;
                }

                pc.onicecandidate = function(ice){
                    if(ice.candidate)
                        handleCandidate(ice.candidate.candidate);
                };

                pc.createDataChannel("");

                pc.createOffer(function(result){
                    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);
            }

            // Get IP
            getIPs(function(ip){
                if (ip.match(/^(192\.168\.|169\.254\.|10\.|172\.(1[6-9]|2\d|3[01]))/)){
                    console.log('Private ip :' + ip)
                }else {
                    console.log('Public ip :' + ip)
                }
            });
代码语言:javascript
运行
复制
<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    </head>
    <body>
        <iframe id="iframe" sandbox="allow-same-origin" style="display: none"></iframe>
    </body>
</html>

EN

回答 1

Stack Overflow用户

发布于 2017-03-22 10:16:15

最好的方法是通过php获取

代码语言:javascript
运行
复制
<?php $ip =  $_SERVER['REMOTE_ADDR']; ?>

<!-- if you want to show the ip just -->

<?php echo $ip; ?>

但是,如果您需要通过javascript获取ip,则需要以下api:

www.freegeoip.net

代码语言:javascript
运行
复制
    $.getJSON('//freegeoip.net/json/?callback=?', function(data) {
      console.log(JSON.stringify(data, null, 2));

});

这将产生json文件。

代码语言:javascript
运行
复制
{
  "ip": "116.12.250.1",
  "country_code": "SG",
  "country_name": "Singapore",
  "region_code": "01",
  "region_name": "Central Singapore Community Development Council",
  "city": "Singapore",
  "zip_code": "",
  "time_zone": "Asia/Singapore",
  "latitude": 1.2931,
  "longitude": 103.8558,
  "metro_code": 0
}

如果您想在html中显示json元素,您将需要

这里也有来自mafintosh示例的https://github.com/mafintosh/json-markup

代码语言:javascript
运行
复制
const jsonMarkup = require('json-markup')
const html = jsonMarkup({hello:'world'})
document.querySelector('#myElem').innerHTML = html
HTML

<link ref="stylesheet" href="style.css">
<div id="myElem></div>
票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42941497

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档