前端獲取IP詳解

一、什麼是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

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
FBXSH的頭像FBXSH
上一篇 2025-04-23 18:08
下一篇 2025-04-23 18:08

相關推薦

  • Centos7配置靜態ip

    本文將詳細闡述如何在Centos7系統中配置靜態ip。 一、查看網路介面 在配置靜態ip之前,我們首先需要查看系統中的網路介面,以確定我們需要配置的網卡是哪一個。 ifconfig…

    編程 2025-04-29
  • Python檢測IP連通

    Python是一門強大的編程語言,常用於網路開發、數據分析等領域。IP地址是網路通信的基礎,在網路通信中,有時需要檢測IP地址是否連通。下面將從多個方面介紹Python檢測IP連通…

    編程 2025-04-28
  • Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901解析

    本文將對Treck TCP/IP Stack 輸入驗證錯誤漏洞CVE-2020-11901進行詳細解析,並提供相關代碼示例。 一、漏洞背景 Treck TCP/IP Stack是一…

    編程 2025-04-27
  • 神經網路代碼詳解

    神經網路作為一種人工智慧技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網路的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網路模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁碟中。在執行sync之前,所有的文件系統更新將不會立即寫入磁碟,而是先緩存在內存…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分散式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • C語言貪吃蛇詳解

    一、數據結構和演算法 C語言貪吃蛇主要運用了以下數據結構和演算法: 1. 鏈表 typedef struct body { int x; int y; struct body *nex…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性感測器,能夠同時測量加速度和角速度。它由三個感測器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變數讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25

發表回復

登錄後才能評論