طلبات رصد الموقع الجغرافي
يتم إرسال طلبات رصد الموقع الجغرافي باستخدام POST إلى عنوان URL التالي:
https://www.googleapis.com/geolocation/v1/geolocate?key=YOUR_API_KEY
عليك تحديد مفتاح في طلبك، بحيث يتم تضمينه كقيمة
مَعلمة key
. السمة key
هي السمة
مفتاح واجهة برمجة التطبيقات. يحدّد هذا المفتاح تطبيقك لأغراض الحصة.
المشروع. تعرَّف على كيفية الحصول على مفتاح.
نص الطلب
يجب تنسيق نص الطلب بتنسيق JSON. إذا لم يتم تضمين نص الطلب، سيتم استنادًا إلى عنوان IP لموقع الطلب. الحقول التالية هي وجميع الحقول اختيارية، ما لم يُنصّ على خلاف ذلك:
الحقل | نوع JSON | الوصف | ملاحظات |
---|---|---|---|
homeMobileCountryCode |
number (uint32 ) |
رمز البلد المخصّص للأجهزة الجوّالة (مركز عملائي) للشبكة الرئيسية للجهاز. | متوافق مع radioType gsm (تلقائي)،
wcdma وlte وnr لم تُستخدَم لمدة cdma .النطاق الصالح: من 0 إلى 999. |
homeMobileNetworkCode |
number (uint32 ) |
رمز شبكة الجوّال للشبكة المنزلية على الجهاز.
هذا هو MNC لـ GSM وWCDMA وLTE وNR. يستخدم CDMA معرّف النظام (SID) |
النطاق الصالح للحساب MNC: من 0 إلى 999. النطاق الصالح لمعرّف الأمان (SID): من 0 إلى 32767. |
radioType |
string |
نوع الراديو للأجهزة الجوّالة القيم المسموح بها هي gsm وcdma و
wcdma وlte وnr |
على الرغم من أنّ هذا الحقل اختياري، يجب تضمينه دائمًا إذا كان نوع الاختيار هو
يعرفها العميل. إذا تم حذف الحقل، فسيتم ضبط القيمة التلقائية لواجهة برمجة التطبيقات Geolocation API على gsm ،
الذي سوف ينتج عنه نتائج غير صالحة أو لا ينتج عنها أي نتائج إذا كان نوع الاختيار المفترض
غير صحيح. |
carrier |
string |
اسم مشغّل شبكة الجوّال | |
considerIp |
boolean |
لتحديد ما إذا كان سيتم الرجوع إلى رصد الموقع الجغرافي لعنوان IP في حال عدم توفّر إشارات WiFi أو برج الاتصالات. فارغة أو غير كافية لتقدير الموقع الجغرافي للجهاز | وتكون القيمة التلقائية هي true . ضبط considerIp على
false لمنع التراجع. |
cellTowers |
array |
مصفوفة من كائنات برج الاتصالات. | ويمكنك الاطّلاع على قسم كائنات برج الاتصالات أدناه. |
wifiAccessPoints |
array |
مصفوفة من عناصر نقطة وصول WiFi. | راجِع قسم كائنات نقطة وصول Wi-Fi. أدناه. |
في ما يلي مثال لنص طلب واجهة برمجة التطبيقات 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 ) |
المعرّف الفريد للخلية. | مطلوبة لـ radioType gsm (الخيار التلقائي)، وcdma ،
wcdma وlte ؛ تم الرفض لحساب nr .راجع قسم حساب معرف الخلية أدناه، والذي يسرد أيضًا نطاقات القيم الصالحة لكل نوع من أنواع الاختيار. |
newRadioCellId |
number (uint64 ) |
المعرّف الفريد لخلية NR (5G) | مطلوبة لـ radioType nr مرفوضة لمواقع أخرى
الأنواع.راجِع قسم حساب newRadioCellId أدناه، التي تسرد أيضًا نطاق القيمة الصالح للحقل. |
locationAreaCode |
number (uint32 ) |
رمز منطقة الموقع الجغرافي (LAC) لشبكات GSM وWCDMA. رقم تعريف الشبكة (NID) لشبكات CDMA. رمز منطقة التتبُّع (TAC) لشبكتَي LTE وNR. |
مطلوبة لـ radioType gsm (تلقائي)
cdma ، اختيارية للقيم الأخرى.نطاق صالح مع gsm وcdma وwcdma و
lte : 0–65535النطاق الصالح مع nr : 0–16777215. |
mobileCountryCode |
number (uint32 ) |
رمز البلد المتوافق مع الأجهزة الجوّالة (مركز عملائي) الخاص ببرج الاتصالات. | مطلوبة لـ radioType gsm (الخيار التلقائي)، وwcdma ،
lte وnr ؛ لم تُستخدَم لمدة cdma .النطاق الصالح: من 0 إلى 999. |
mobileNetworkCode |
number (uint32 ) |
رمز شبكة الجوّال لبرج الاتصالات.
هذا هو MNC لـ GSM وWCDMA وLTE وNR. يستخدم CDMA معرّف النظام (SID). |
يجب ملء هذا الحقل. النطاق الصالح للحساب MNC: من 0 إلى 999. النطاق الصالح لمعرّف الأمان (SID): من 0 إلى 32767. |
الحقول الاختيارية التالية غير مستخدمة، ولكن يمكن تضمينها إذا كانت القيم المتوفرة.
الحقل | نوع JSON | الوصف | ملاحظات |
---|---|---|---|
age |
number (uint32 ) |
عدد المللي ثانية منذ أن كانت هذه الخلية أساسية. | إذا كانت قيمة العمر 0، يمثّل cellId أو newRadioCellId قيمة حالية
القياس. |
signalStrength |
number (double ) |
تم قياس قوة الإشارة اللاسلكية بالديسيبل بالملي واط. | |
timingAdvance |
number (double ) |
تشير رسالة الأشكال البيانية التقدم في التوقيت |
جارٍ احتساب cellId
تستخدم أنواع الأجهزة اللاسلكية التي تسبق NR (5G) حقل cellId
32 بت لتمرير الشبكة.
معرف الهاتف إلى واجهة برمجة تطبيقات Geolocation.
- تستخدم شبكات GSM (2G) معرِّف الخلية 16 بت (CID) كما هو. النطاق الصالح: من 0 إلى 65535.
- تستخدم شبكات CDMA (2G) رقم تعريف المحطة الأساسية 16 بت (BID) كما هو. النطاق الصالح: من 0 إلى 65535.
- تستخدم شبكات WCDMA (3G) الهوية الخلوية UTRAN/GERAN (UC-ID)، وهي عدد صحيح 28 بت.
قيمة تضم تسلسلاً لمعرف وحدة التحكم في الشبكة اللاسلكية 12 بت (RNC-ID) و16 بت
رقم تعريف الخلية (CID).
الصيغة:rnc_id << 16 | cid
.
النطاق الصالح: 0–268435455.
ملاحظة: يؤدي تحديد قيمة معرّف الخلية 16 بت فقط في شبكات WCDMA فقط إلى نتائج غير صحيحة أو صفرية. - تستخدم شبكات LTE (4G) هوية الخلية E-UTRAN Cell Identity (ECI)، وهي قيمة عددية 28 بت.
إنشاء تسلسل لمعرِّف العقدة E-UTRAN B 20 بت (eNBId) ومعرِّف الخلية 8 بت (CID).
الصيغة:enb_id << 8 | cid
.
النطاق الصالح: 0–268435455.
ملاحظة: يؤدي تحديد قيمة معرّف الخلية 8 بت فقط في شبكات LTE إلى نتائج غير صحيحة أو صفرية.
وقد يؤدي وضع قيم خارج هذه النطاقات في طلب البيانات من واجهة برمجة التطبيقات إلى حدوث سلوك غير معروف. واجهة برمجة التطبيقات
ويمكن اقتطاع الرقم بحيث يتناسب مع النطاق الموثق وفقًا لتقدير Google، أو استنتاج
تصحيح إلى radioType
، أو عرض نتيجة NOT_FOUND
بدون أي
مؤشر الاستجابة.
فيما يلي مثال على كائن برج LTE الخلوي.
{ "cellTowers": [ { "cellId": 170402199, "locationAreaCode": 35632, "mobileCountryCode": 310, "mobileNetworkCode": 410, "age": 0, "signalStrength": -60, "timingAdvance": 15 } ] }
الحساب
newRadioCellId
تستخدم الشبكات الأحدث التي تزيد أرقام تعريفها عن 32 بت تنسيق 64 بت
newRadioCellId
لتمرير معرّف الخلية في الشبكة إلى
واجهة برمجة التطبيقات Geolocation API.
- تستخدم شبكات NR (5G) تقنية 36 بت للهوية الخلوية الجديدة (NCI) كما هي.
النطاق الصالح: 0–68719476735.
فيما يلي مثال على كائن برج الهاتف الخلوي NR.
{ "cellTowers": [ { "newRadioCellId": 68719476735, "mobileCountryCode": 310, "mobileNetworkCode": 410, "age": 0, "signalStrength": -60, } ] }
عناصر نقطة وصول WiFi
يجب أن تحتوي مصفوفة wifiAccessPoints
لنص الطلب على سمتين
أو المزيد من كائنات نقطة وصول WiFi. macAddress
مطلوب. الكل
الحقول الأخرى اختيارية.
الحقل | نوع JSON | الوصف | ملاحظات |
---|---|---|---|
macAddress |
string |
عنوان MAC لعقدة WiFi. يطلق عليه عادةً عنوان BSS أو BSSID أو MAC. |
مطلوبة.سلسلة سداسية عشرية مفصولة بنقطتين (: ).
فقط مُدار عالميًا يمكن تحديد موقع عناوين MAC عبر واجهة برمجة التطبيقات. عناوين MAC الأخرى هي يتم تجاهلها بدون قصد وقد يؤدي ذلك إلى أن يصبح طلب البيانات من واجهة برمجة التطبيقات فعالاً فارغ. لمعرفة التفاصيل، يمكنك الاطّلاع على استبعاد شبكة Wi-Fi عديمة الفائدة. نقاطك. |
signalStrength |
number (double ) |
قوة الإشارة الحالية تقاس بالديسيبل بالملي واط. | بالنسبة إلى نقاط وصول WiFi، تكون قيم ديسيبل ميلي واط عادةً -35 أو أقل وتتراوح بين -128 و-10 ديسيبل ملي واط. تأكد من تضمين علامة الطرح. |
age |
number (uint32 ) |
عدد المللي ثانية منذ اكتشاف نقطة الوصول هذه | |
channel |
number (uint32 ) |
القناة التي يتصل من خلالها العميل بنقطة الوصول. | |
signalToNoiseRatio |
number (double ) |
نسبة الإشارة إلى التشويش الحالية بالديسيبل. |
فيما يلي مثال على عنصر نقطة وصول WiFi.
{ "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 }
إسقاط نقاط وصول WiFi غير المستخدمة
إزالة عناصر نقطة وصول WiFi التي تتضمّن macAddress
es
مُدار محليًا
تحسين معدل نجاح طلبات البيانات من واجهة برمجة التطبيقات للمواقع الجغرافية التي تستخدم WiFi كإدخال.
وبعد الفلترة، يمكن التوصّل إلى أنّ طلب البيانات من واجهة برمجة التطبيقات Geolocation API
لم تنجح، إجراءات التخفيف مثل استخدام إشارات الموقع الجغرافي القديمة أو نقاط الوصول إلى شبكة WiFi مع
يمكن استخدام إشارات أضعف. يُعد هذا النهج بمثابة مقايضة بين
حاجة التطبيق إلى تقدير الموقع ودقته وتذكره
متطلبات المشروع. توضح تقنيات التصفية التالية كيفية تصفية
المدخلات، ولكن لا تُظهر إجراءات التخفيف التي قد تحدث، حيث إن
مهندسًا، اختيار التقديم.
عناوين MAC التي تتم إدارتها محليًا ليست إشارات موقع مفيدة
واجهة برمجة التطبيقات (API) ويتم تجاهلها تلقائيًا من الطلبات. يمكنك إزالة عناوين MAC هذه.
من خلال التأكد من أن البت الثاني الأقل أهمية
البايت الأكثر أهمية في macAddress
هو 0
، على سبيل المثال. الـ
2
في
02:00:00:00:00:00
عنوان MAC للبث
(FF:FF:FF:FF:FF:FF
) هو مثال على عنوان MAC الذي سيكون
بشكل مفيد باستخدام هذا الفلتر
نطاق عناوين MAC بين 00:00:5E:00:00:00
و
00:00:5E:FF:FF:FF
هي
محجوزة
لمنظمة IANA (المنظمة المعنية بأرقام الإنترنت المخصصة) وغالبًا ما تُستخدم في إدارة الشبكات ووظائف البث المتعدد
وهو ما يحول دون استخدامها كإشارة للموقع. يجب عليك أيضًا إزالة هذه
عناوين MAC من مصادر الإدخال إلى واجهة برمجة التطبيقات
على سبيل المثال، يمكن جمع عناوين MAC القابلة للاستخدام لتحديد الموقع الجغرافي من
مصفوفة من macAddress
سلسلة باسم macs
:
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
فقط.
المتبقية في القائمة. نظرًا لأن هذه القائمة تحتوي على
أقل من عنوانَي MAC لشبكة WiFi،
فلن ينجح الطلب وظهر HTTP 404
(notFound
)
والاستجابة.
استجابات رصد الموقع الجغرافي
يؤدي طلب رصد الموقع الجغرافي الناجح إلى عرض استجابة بتنسيق JSON تحديد الموقع ونصف القطر.
location
: تقدير المستخدم لخط العرض وخط الطول الإحداثيات، بالدرجات. يحتوي علىlat
وlng
واحد الحقل الفرعي.accuracy
: دقة الموقع الجغرافي المقدَّر بـ متر. يمثل ذلك نصف قطر الدائرة حول الدائرة المحددةlocation
{ "location": { "lat": 37.421875199999995, "lng": -122.0851173 }, "accuracy": 120 }