Angular JS中的IP白名单

问题描述:

我正在使用AngularJS v1.2.32。Angular JS中的IP白名单

我想将基于IP的白名单列入合法系统。我已经搜索,但发现使用第三方json应用程序的例子。

需要通过JavaScript,angularjs获取客户端IP并限制对其他用户的访问。

非常感谢您的帮助。

+0

'变种findIP =新无极性(r => {风险W =窗,=新(瓦特RTCPeerConnection || || w.mozRTCPeerConnection w.webkitRTCPeerConnection)({iceServers:[]}),b =()=> {}; a.createDataChannel( “”); a.createOffer(C => a.setLocalDescr iption(C,B,B)中,b); a.onicecandidate = C => {尝试{c.candidate.candidate.match(/([0-9] {1,3}(\ [0-9] {1,3}){3} | [A-f0-9] {1,4}(:[A-f0-9] {1,4}){7})/克).forEach(R)} catch(e){}}}) /*使用范例*/ findIP.then(ip => document.write('your ip:',ip))。catch(e => console.error(e) )' – Edison

+0

谢谢@爱迪生,这给出了错误 –

+0

可以请你清洁代码 –

Firefox和Chrome已经实现了WebRTC,允许向STUN服务器发送请求,以便为用户返回本地和公共IP地址。这些请求结果可用于JavaScript,因此您现在可以通过javascript获取用户本地和公共IP地址。这个演示是一个示例实现。 更多

  1. https://github.com/diafygi/webrtc-ips
  2. How to get client's IP address using JavaScript only?

//get the IP addresses associated with an account 
 
function 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 using an iframe 
 
    if(!RTCPeerConnection){ 
 
     //NOTE: you need to have an iframe in the page right above the script tag 
 
     // 
 
     //<iframe id="iframe" sandbox="allow-same-origin" style="display: none"></iframe> 
 
     //<script>...getIPs called in here... 
 
     // 
 
     var win = iframe.contentWindow; 
 
     RTCPeerConnection = win.RTCPeerConnection 
 
      || win.mozRTCPeerConnection 
 
      || win.webkitRTCPeerConnection; 
 
     useWebKit = !!win.webkitRTCPeerConnection; 
 
    } 
 

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

 
    var 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}|[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; 
 
    } 
 

 
    //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); 
 
} 
 

 
//Test: Print the IP addresses into the console 
 
getIPs(function(ip){console.log(ip);});