目录
一、接口介绍
二、申请密钥Key
1.登录高德开放平台,进入控制台
2.在应用管理中创建新的应用
3.为应用添加Key
三、在Unity中应用
1.定位数据结构
2.函数封装
3.测试
一、接口介绍Http接口,根据输入的IP地址,快速定位IP所在位置,仅支持IPV4,不支持国外IP解析。
二、申请密钥Key 1.登录高德开放平台,进入控制台 2.在应用管理中创建新的应用根据官方文档中给出的返回结果参数说明定义相应的数据结构
///
/// IP定位响应数据结构
///
[Serializable]
public class IPLocationResponse
{
///
/// 返回结果状态值
/// 0表示失败 1表示成功
///
public string status;
///
/// 返回状态说明
/// status为0时,info返回错误原因 否则返回OK
///
public string info;
///
/// 状态码 10000表示正确,详情参阅官方文档info状态表
///
public string infocode;
///
/// 省份名称
///
public string province;
///
/// 城市名称
///
public string city;
///
/// 城市的adcode编码
///
public string adcode;
///
/// 所在城市矩形区域范围
///
public string rectangle;
}
2.函数封装
using System;
using UnityEngine;
using System.Collections;
using UnityEngine.Networking;
///
/// IP定位
///
public class IPLocation
{
//在高德开放平台创建应用获取密钥
private static readonly string key = "";
///
/// 发起网络请求
///
/// 要定位的IP地址
/// 回调函数
///
public static IEnumerator SendWebRequest(string ip, Action callback)
{
string url = string.Format("https://restapi.amap.com/v3/ip?key={0}&ip={1}", key, ip);
using(UnityWebRequest request = UnityWebRequest.Get(url))
{
yield return request.SendWebRequest();
if (!request.isHttpError && !request.isNetworkError)
{
Debug.Log(request.downloadHandler.text);
IPLocationResponse response = JsonUtility.FromJson(request.downloadHandler.text);
callback?.Invoke(response);
}
else
{
Debug.Log("调用IP定位接口失败:" + request.error.ToString());
}
}
}
}
3.测试
using UnityEngine;
public class IPLocationExample : MonoBehaviour
{
private void Start()
{
StartCoroutine(IPLocation.SendWebRequest("114.222.121.24", s => { }));
}
}