一、什麼是IP地址?
IP地址是Internet Protocol的簡稱,翻譯成中文就是「網際協議」,它是在網路上唯一標識一個節點(設備)的方式。每個節點(設備)都有一個獨特的IP地址,這個IP地址可以用來在網路上找到這個節點(設備)。
IP地址是一個由32位二進位數分成4組,每組8位,轉換成十進位後加上小數點連成的字元串。例如,「192.168.1.1」就是一個IP地址。
二、前端獲取IP的方式
1.使用Ajax發送請求獲取客戶端IP地址
$.ajax({
url: "https://api.ipify.org?format=jsonp&callback=?",
dataType: "jsonp",
success: function(json) {
var ip = json.ip;
console.log(ip);
}
});
這種方式通過向第三方介面發送請求,從響應中獲取IP地址。它的優點是代碼量較小,容易實現,在一些簡單的應用場景下比較實用;缺點是需要向第三方介面發送請求,可能會受到介面訪問限制,而且該IP地址是客戶端的公網IP,不能獲取客戶端的區域網IP。
2.利用WebRTC API獲取本機IP地址
function getIPs(callback){
var ip_dups = {};
var RTCPeerConnection = window.RTCPeerConnection
|| window.mozRTCPeerConnection
|| window.webkitRTCPeerConnection;
if (!RTCPeerConnection) {
callback([]);
return;
}
var pc = new RTCPeerConnection({iceServers:[]}),
noop = function(){};
pc.createDataChannel("");
pc.createOffer(function(sdp) {
sdp.sdp.split('\n').forEach(function(line) {
if (line.indexOf('candidate') < 0) return;
line.split(' ').forEach(function(part) {
if (part.indexOf('192.168.') === 0 || part.indexOf('172.') === 0 || part.indexOf('10.') === 0) {
if (!(part in ip_dups)) {
ip_dups[part] = true;
}
}
});
});
Object.keys(ip_dups).forEach(function(ip) {
callback(ip);
});
}, noop);
}
這種方式使用瀏覽器的WebRTC API獲取本機IP地址。它的優點是可以獲取客戶端的區域網IP地址;缺點是需要比較複雜的代碼實現,而且可能會有跨瀏覽器兼容性問題。
3.利用Websocket獲取客戶端IP地址
var ws = new WebSocket('ws://example.com:1234');
ws.onopen = function(){
var ip = ws._socket.remoteAddress;
console.log(ip);
};
這種方式利用Websocket獲取客戶端IP地址。它的優點是可以獲得客戶端的IP地址;缺點是必須要建立Websocket連接,而且代碼比較複雜。
三、總結
前端獲取IP地址的方式有很多種,在實際應用中應該根據不同的場景選擇不同的方式。在選擇的同時,要考慮到代碼實現的複雜度、跨瀏覽器兼容性以及介面訪問限制等因素。
原創文章,作者:FBXSH,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/371546.html
微信掃一掃
支付寶掃一掃