2016-03-31 19 views
-1

Çalışanlara sahte e-posta gönderdiğim küçük bir alıştırmayı yürütüyorum ve sadece bağlantıyı kimlerin açtığını kontrol etmek istiyorum. Bunun için php veya php veya http://l2.io/, http://www.hashemian.com/tools/visitor-IP.htm gibi diğer komut dosyalarını kullanarak IP alabilirim. Bu iyi, ancak hepsi bir yönlendiriciye bağlı oldukları için, herkesin tıklaması durumunda sadece tek bir IP olacağını biliyorum. bağlantı. Bu yüzden özel IP'leri de almayı düşündüm, böylece yönlendirici kayıtlarını kullanarak izlenebilirler. Özel IP alabilmek içinZiyaretçiler özel IP ve ziyaretçi takip etmek için veritabanında saklayın

, bu kullanıyorum - How to get client's IP address using javascript only?

Şimdi IP bir veritabanına sayfa yüklendiğinde içine saklamak istiyorum. Bilgime göre, değeri bir veritabanına depolamak için ajax kullanılarak yapılabilir. Fakat bu değeri bir değişkene nasıl koyabilirim?

bu yapılabilir başka yolu varsa veya onun özel IP almadan linki açtı çalışanın izlemek mümkün, daha sonra da ben buna açığım eğer

<!DOCTYPE html> 
 
<html> 
 
    <head> 
 
     <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
 
    </head> 
 
    <body> 
 
     <h4> 
 
      
 
     </h4> 
 
     
 
     <h4>Your local IP addresses:</h4> 
 
     <ul></ul> 
 
     <h4>Your public IP addresses:</h4> 
 
     <ul></ul> 
 
     <h4>Your IPv6 addresses:</h4> 
 
     <ul></ul> 
 
     <iframe id="iframe" style="display: none"></iframe> 
 
     <script> 
 
      //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); 
 
      } 
 

 
      //insert IP addresses into the page 
 
      getIPs(function(ip){ 
 
       var li = document.createElement("li"); 
 
       li.textContent = ip; 
 

 
       //local IPs 
 
       if (ip.match(/^(192\.168\.|169\.254\.|10\.|172\.(1[6-9]|2\d|3[01]))/)) 
 
        document.getElementsByTagName("ul")[0].appendChild(li); 
 

 
       //IPv6 addresses 
 
       else if (ip.match(/^[a-f0-9]{1,4}(:[a-f0-9]{1,4}){7}$/)) 
 
        document.getElementsByTagName("ul")[2].appendChild(li); 
 

 
       //assume the rest are public IPs 
 
       else 
 
        document.getElementsByTagName("ul")[1].appendChild(li); 
 
      }) 
 
\t \t \t 
 
\t \t \t ; 
 
     </script> 
 
    </body> 
 
</html>

. Teşekkürler

+3

Neden bağlantınızda yalnızca özel get parametrelerini kullanmıyorsunuz; onları e-posta adresine bağlı olarak kaydedin ve paragraf – baao

+0

@ mmm için kontrol edin, bunun nasıl yapılabileceği hakkında daha fazla bilgi verebilir misiniz? –

+0

IP'leri bir veritabanında depolamakla aynı prensip, IP'yi almak yerine postayla gönderdiğiniz benzersiz parametreyi '$ _GET' yaparsınız. – Epodax

cevap

0

Kullanıcılara "benzersiz kimlik" içeren bir bağlantı gönderin, örneğin: www.mysite.com?emailID=Ajk2j18ysdcnb, gönderdikten sonra kimliğinizi takip edin ve bağlantıyı tıklattığında GET parametrelerinde bunları arayın.

DÜZENLEME

i kullanıcı geçerli bir kimlik olmadan sayfaya erişememiştir ve bir IP adresinizi taklit engeller olarak bu yöntem daha güvenli olduğunu eklemek istiyorum

. Javascript tamamen müşteri tarafıdır ve hiçbir şey istedikleri her şeyi göndermekten vazgeçmez.

İlgili konular