地理位置要求
地理位置要求會使用 POST 傳送至下列網址:
https://www.googleapis.com/geolocation/v1/geolocate?key=YOUR_API_KEY
您必須在要求中指定鍵,並新增為
key
參數。key
是應用程式的 API 金鑰。為計算配額,這組金鑰會識別您的應用程式
以自動化做法管理成本瞭解如何取得金鑰。
要求主體
要求主體必須採用 JSON 格式。如果未包含要求主體,結果 會根據要求位置的 IP 位址傳回。以下欄位 ,且除非另有註明,否則所有欄位均為選填:
欄位 | JSON 類型 | 說明 | 附註 |
---|---|---|---|
homeMobileCountryCode |
number (uint32 ) |
裝置家用網路的行動裝置國家/地區代碼 (MCC)。 | 支援 radioType gsm (預設),
wcdma 、lte 和 nr ;未用於 cdma 。有效範圍:0 至 999。 |
homeMobileNetworkCode |
number (uint32 ) |
裝置家用網路的行動網路代碼。
這是 GSM、WCDMA、LTE 和 NR 的 MNC。 CDMA 使用系統 ID (SID) |
MNC 的有效範圍:0–999。 SID 的有效範圍:0–32767。 |
radioType |
string |
手機無線電類型。支援的值為 gsm 、cdma 、
wcdma 、lte 和nr 。 |
雖然這是選填欄位,但如果無線電類型為
用戶端密碼。 如果省略這個欄位,Geolocation API 預設為 gsm 。
如果假設使用的無線電類型為
不正確。 |
carrier |
string |
貨運公司名稱。 | |
considerIp |
boolean |
指定是否要在缺少 Wi-Fi 和基地台信號時,改回使用 IP 地理位置。 空白,或是資訊不足,無法判斷裝置位置。 | 預設為 true 。將「considerIp 」設為
false ,以避免回溯。 |
cellTowers |
array |
電信塔物件的陣列。 | 請參閱下方的基地台物件一節。 |
wifiAccessPoints |
array |
Wi-Fi 存取點物件的陣列。 | 請參閱「WiFi 存取點物件」一節 。 |
以下是 Geolocation API 要求主體的範例。
{ "homeMobileCountryCode": 310, "homeMobileNetworkCode": 410, "radioType": "gsm", "carrier": "Vodafone", "considerIp": true, "cellTowers": [ // See the Cell Tower Objects section below. ], "wifiAccessPoints": [ // See the WiFi Access Point Objects section below. ] }
行動通信基地台物體
要求主體的 cellTowers
陣列含有零個或多個陣列
行動通信基地台物件
欄位 | JSON 類型 | 說明 | 附註 |
---|---|---|---|
cellId |
number (uint32 ) |
儲存格的專屬 ID。 | 對於 radioType gsm (預設)、cdma 、
wcdma 和 lte ;已拒絕 的時間nr 。請參閱下方的計算儲存格 ID 一節,其中也會列出 每個無線電類型的有效值範圍 |
newRadioCellId |
number (uint64 ) |
NR (5G) 儲存格的專屬 ID。 | 對於 radioType nr ,此為必填屬性;已拒絕 (其他)
。請參閱下方的計算 newRadioCellId 一節。 該欄位也會列出欄位的有效值範圍。 |
locationAreaCode |
number (uint32 ) |
GSM 和 WCDMA 網路的區碼 (LAC)。 CDMA 聯播網的網路 ID (NID)。 LTE 和 NR 聯播網的追蹤區碼 (TAC)。 |
radioType gsm (預設) 和 cdma 為必填,其他值則為選填。使用 gsm 、cdma 、wcdma 和
lte :0–65535。搭配 nr 的有效範圍:0 到 16777215。 |
mobileCountryCode |
number (uint32 ) |
基地台的行動裝置國家/地區代碼 (MCC)。 | 對於 radioType gsm (預設)、wcdma 、
lte 和 nr ;未用於 cdma 。有效範圍:0 至 999。 |
mobileNetworkCode |
number (uint32 ) |
基地台的行動網路代碼。
這是 GSM、WCDMA、LTE 和 NR 的 MNC。 CDMA 會使用系統 ID (SID)。 |
必要。 MNC 的有效範圍:0–999。 SID 的有效範圍:0–32767。 |
以下為不使用的選填欄位,但如果值有 廣告。
欄位 | JSON 類型 | 說明 | 附註 |
---|---|---|---|
age |
number (uint32 ) |
這個儲存格是主要儲存格後經過的毫秒數。 | 如果年齡為 0,cellId 或 newRadioCellId 代表現行值
成效評估方式 |
signalStrength |
number (double ) |
無線電訊號強度以 dBm 為單位。 | |
timingAdvance |
number (double ) |
時間進展 值。 |
計算 cellId
NR (5G) 之前的無線電類型使用 32 位元 cellId
欄位傳遞網路
將儲存格 ID 對應至 Geolocation API。
- GSM (2G) 網路會使用 16 位元行動網路 ID (CID) 的方式,有效範圍:0 - 65535。
- CDMA (2G) 網路會使用 16 位元基準站 ID (BID)。有效範圍:0 - 65535。
- WCDMA (3G) 網路使用 UTRAN/GERAN Cell Identity (UC-ID),此為 28 位元整數
值串連 12 位元無線電網路控制器識別碼 (RNC-ID) 和 16 位元
基地台 ID (CID):
公式:rnc_id << 16 | cid
。
有效範圍:0–268435455。
注意:如果在 WCDMA 網路中只指定 16 位元行動網路 ID 值, 如果有錯誤或零結果 - LTE (4G) 網路使用 E-UTRAN Cell Identity (ECI),此為 28 位元整數值
將 20 位元 E-UTRAN 節點 B ID (eNBId) 和 8 位元行動網路 ID (CID) 串連起來。
公式:enb_id << 8 | cid
。
有效範圍:0–268435455。
注意:如果在 LTE 網路中只指定 8 位元行動網路 ID 值, 如果有錯誤或零結果
在 API 要求中放置超出範圍的值可能會導致未定義的行為。API
Google 可自行斟酌將電話號碼截斷至規定的範圍內,推斷出
修正為 radioType
,或在沒有任何條件的情況下傳回 NOT_FOUND
結果
回應中的指標。
LTE 基地台物件範例如下。
{ "cellTowers": [ { "cellId": 170402199, "locationAreaCode": 35632, "mobileCountryCode": 310, "mobileNetworkCode": 410, "age": 0, "signalStrength": -60, "timingAdvance": 15 } ] }
計算中
newRadioCellId
如果較新的網路 (基地台 ID 超過 32 位元),請使用 64 位元
newRadioCellId
欄位,用於將聯播網儲存格 ID 傳遞給
Geolocation API。
- NR (5G) 網路會使用 36 位元的新型無線電基地台身分 (NCI)。
有效範圍:0–68719476735。
以下是 NR 基地台物件的範例。
{ "cellTowers": [ { "newRadioCellId": 68719476735, "mobileCountryCode": 310, "mobileNetworkCode": 410, "age": 0, "signalStrength": -60, } ] }
Wi-Fi 存取點物件
要求主體的 wifiAccessPoints
陣列必須包含兩個
或多個代表「實體差異」的 Wi-Fi 存取點物件
存取點裝置「macAddress
」為必填欄位;則所有其他欄位
選用。
欄位 | JSON 類型 | 說明 | 附註 |
---|---|---|---|
macAddress |
string |
WiFi 節點的 MAC 位址。這項資訊通常稱為 BSS、BSSID 或 MAC 位址。 |
必要欄位。以半形冒號分隔 (: ) 的十六進位字串。
僅限 通用管理 MAC 位址可透過 API 找出。系統會自動捨棄其他 MAC 位址,這可能會導致 API 要求變成空白。詳情請參閱捨棄無用 Wi-Fi 存取權 積分。 |
signalStrength |
number (double ) |
目前的訊號強度,以 dBm 為單位。 | 對於 Wi-Fi 存取點,dBm 值通常為 -35 以下,且範圍介於 -128 至 -10 dBm 之間。 (別忘了加上減號)。 |
age |
number (uint32 ) |
偵測到這個存取點至今的毫秒數。 | |
channel |
number (uint32 ) |
用戶端與存取點進行通訊的頻道。 | |
signalToNoiseRatio |
number (double ) |
目前訊號與雜訊的比率 測量單位 |
以下是 Wi-Fi 存取點物件的範例。
{ "macAddress": "f0:d5:bf:fd:12:ae", "signalStrength": -43, "signalToNoiseRatio": 0, "channel": 11, "age": 0 }
要求範例
如果您想試用 Geolocation API ,請將下列 JSON 儲存至檔案:
{ "considerIp": "false", "wifiAccessPoints": [ { "macAddress": "3c:37:86:5d:75:d4", "signalStrength": -35, "signalToNoiseRatio": 0 }, { "macAddress": "30:86:2d:c4:29:d0", "signalStrength": -35, "signalToNoiseRatio": 0 } ] }
接著,您可以使用 cURL 將 透過指令列發出要求:
$ curl -d @your_filename.json -H "Content-Type: application/json" -i "https://www.googleapis.com/geolocation/v1/geolocate?key=YOUR_API_KEY"
上述 MAC 位址的回應如下所示:
{ "location": { "lat": 37.4241173, "lng": -122.0915717 }, "accuracy": 20 }
捨棄未使用的 Wi-Fi 存取點
移除具有 macAddress
的 Wi-Fi 存取點物件
本機管理
可以提高採用 Wi-Fi 做為輸入資料之 Geolocation API 呼叫的成功率。
篩選後,如果系統傳回 Geolocation API 呼叫
未使用這些因應措施,例如使用較舊的位置信號或 Wi-Fi AP
較弱的信號可用此方法可在
對位置估計以及其精確度和喚回度的需求
Google Cloud 就是最佳選擇下列篩選技術示範如何篩選
,但請不要顯示您或許像應用程式一樣的
可以選擇套用
本機管理的 MAC 位址對
而且會從要求中直接捨棄。您可以移除這類 MAC 位址
就必須確保
macAddress
中最重要的位元組是 0
,例如這個
2
代表 1 位元,
02:00:00:00:00:00
。廣播 MAC 位址
(FF:FF:FF:FF:FF:FF
) 是 MAC 位址示例:
可能會被這個篩選器排除
介於 00:00:5E:00:00:00
到 MAC 位址的範圍
00:00:5E:FF:FF:FF
是
預訂
,且通常用於網路管理和多點傳送功能
這時就不能再當做地區信號使用建議您一併移除這些
輸入至 API 的 MAC 位址。
舉例來說,您可以從
名為 macs
的 macAddress
字串陣列:
String[] macs = {"12:34:56:78:9a:bc", "1c:34:56:78:9a:bc", "00:00:5e:00:00:01"}; ArrayList<String> _macs = new ArrayList<>(Arrays.asList(macs)); _macs.removeIf(m -> !(0 == (2 & Integer.parseInt(m.substring(1, 2), 16)) && !m.substring(0, 8).toUpperCase().equals("00:00:5E")));
macs = ['12:34:56:78:9a:bc', '1c:34:56:78:9a:bc', '00:00:5e:00:00:01'] macs = [m for m in macs if (0 == (2 & int(m[1], 16)) and m[:8].upper() != '00:00:5E')]
macs = ['12:34:56:78:9a:bc', '1c:34:56:78:9a:bc', '00:00:5e:00:00:01']; macs = macs.filter(m => 0 === (2 & Number.parseInt(m[1], 16)) && m.substr(0, 8).toUpperCase() !== '00:00:5E');
使用這個篩選器後,系統只會顯示 1c:34:56:78:9a:bc
項結果
。因為這份清單有
少於 2 個 Wi-Fi MAC 位址,
要求失敗時傳回 HTTP 404
(notFound
)
回應。
地理位置回應
成功的地理位置要求會傳回 JSON 格式的回應 定義位置和半徑。
location
:使用者預估的經緯度 座標,單位為度包含一個lat
和一個lng
子欄位。accuracy
:大概位置的準確度,位於 公尺。這個屬性代表指定周圍圓形的半徑location
。
{ "location": { "lat": 37.421875199999995, "lng": -122.0851173 }, "accuracy": 120 }