![](/img/trans.png)
[英]Error Using GoogleMaps.LocationServices to Find Latitude and Longitude in C#
[英]How to find latitude and longitude using C#
我在 C# 中有一個WCF
服務。
在服務調用客戶端發送一個城市名稱。 我想將城市名稱轉換為緯度和經度,並存儲在人口統計數據下的數據庫中。
我打算使用 Google API 來實現上述功能。
我已從 Google 及其“服務帳戶”類型獲得了一個 API 密鑰。
如何使用哪些 API 獲取緯度和經度?
我需要安裝一些SDK
還是任何REST
服務都可以?
您可以嘗試 NuGet 包GoogleMaps.LocationServices ,或者只是對其源代碼進行旋轉。 它使用 Google 的 REST API 獲取給定地址的經緯度,反之亦然,無需 API 密鑰。
你像這樣使用它:
public static void Main()
{
var address = "Stavanger, Norway";
var locationService = new GoogleLocationService();
var point = locationService.GetLatLongFromAddress(address);
var latitude = point.Latitude;
var longitude = point.Longitude;
// Save lat/long values to DB...
}
如果你想使用谷歌地圖 API 看看他們的 REST API,你不需要安裝谷歌地圖 API 只需發送一個請求
http://maps.googleapis.com/maps/api/geocode/xml?address=1600+Amphitheatre+Parkway,+Mountain+View,+CA&sensor=true_or_false
你會得到一個響應 XML。
對於響應 JSON:
https://maps.googleapis.com/maps/api/geocode/json?address=1600+Estância+Sergipe,&key=**YOUR_API_KEY**
有關更多信息,請查看
https://developers.google.com/maps/documentation/geocoding/index#GeocodingRequests
您可以在特定的 url 中傳遞地址 .. 並在返回值 dt(datatable) 中獲得緯度和經度
string url = "http://maps.google.com/maps/api/geocode/xml?address=" + address+ "&sensor=false";
WebRequest request = WebRequest.Create(url);
using (WebResponse response = (HttpWebResponse)request.GetResponse())
{
using (StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8))
{
DataSet dsResult = new DataSet();
dsResult.ReadXml(reader);
DataTable dtCoordinates = new DataTable();
dtCoordinates.Columns.AddRange(new DataColumn[4] { new DataColumn("Id", typeof(int)),
new DataColumn("Address", typeof(string)),
new DataColumn("Latitude",typeof(string)),
new DataColumn("Longitude",typeof(string)) });
foreach (DataRow row in dsResult.Tables["result"].Rows)
{
string geometry_id = dsResult.Tables["geometry"].Select("result_id = " + row["result_id"].ToString())[0]["geometry_id"].ToString();
DataRow location = dsResult.Tables["location"].Select("geometry_id = " + geometry_id)[0];
dtCoordinates.Rows.Add(row["result_id"], row["formatted_address"], location["lat"], location["lng"]);
}
}
return dtCoordinates;
}
/*Ready to use code : simple copy paste GetLatLong*/
public class AddressComponent
{
public string long_name { get; set; }
public string short_name { get; set; }
public List<string> types { get; set; }
}
public class Northeast
{
public double lat { get; set; }
public double lng { get; set; }
}
public class Southwest
{
public double lat { get; set; }
public double lng { get; set; }
}
public class Bounds
{
public Northeast northeast { get; set; }
public Southwest southwest { get; set; }
}
public class Location
{
public double lat { get; set; }
public double lng { get; set; }
}
public class Northeast2
{
public double lat { get; set; }
public double lng { get; set; }
}
public class Southwest2
{
public double lat { get; set; }
public double lng { get; set; }
}
public class Viewport
{
public Northeast2 northeast { get; set; }
public Southwest2 southwest { get; set; }
}
public class Geometry
{
public Bounds bounds { get; set; }
public Location location { get; set; }
public string location_type { get; set; }
public Viewport viewport { get; set; }
}
public class Result
{
public List<AddressComponent> address_components { get; set; }
public string formatted_address { get; set; }
public Geometry geometry { get; set; }
public string place_id { get; set; }
public List<string> types { get; set; }
}
public class RootObject
{
public List<Result> results { get; set; }
public string status { get; set; }
}
public static RootObject GetLatLongByAddress(string address)
{
var root = new RootObject();
var url =
string.Format(
"http://maps.googleapis.com/maps/api/geocode/json?address={0}&sensor=true_or_false", address);
var req = (HttpWebRequest)WebRequest.Create(url);
var res = (HttpWebResponse)req.GetResponse();
using (var streamreader=new StreamReader(res.GetResponseStream()))
{
var result = streamreader.ReadToEnd();
if (!string.IsNullOrWhiteSpace(result))
{
root = JsonConvert.DeserializeObject<RootObject>(result);
}
}
return root;
}
/* Call This*/
var destination_latLong = GetLatLongByAddress(um.RouteDestination);
var lattitude =Convert.ToString( destination_latLong.results[0].geometry.location.lat, CultureInfo.InvariantCulture);
var longitude=Convert.ToString( destination_latLong.results[0].geometry.location.lng, CultureInfo.InvariantCulture);
Google 的替代方案是OpenStreetMap 的 Nominatim API 。
與 Google 不同,它們沒有每日限制,只要您不過度使用它們(每秒超過 1 個請求)。 下面的代碼適用於 Blazor 服務器。
[Inject] IJSRuntime _js { get; set; }
public async Task<Coordinates> GetCoordinates(string city) {
Coordinates coordinates = new Coordinates();
string query= String.Format("https://nominatim.openstreetmap.org/search.php?q={0}&format=jsonv2", city);
string result = GetRequest(query); //returns a stringified array of js objects
IJSObjectReference objArray= await _js.InvokeAsync<IJSObjectReference>("JSON.parse", result); //parse the string to a js array
IJSObjectReference obj = await objArray.InvokeAsync<IJSObjectReference>("shift"); //take the first element in the array
string jsonResult = await _js.InvokeAsync<string>("JSON.stringify", obj);
dynamic dynamicResult = JObject.Parse(jsonResult);
coordinates.Latitude= dynamicResult.lat;
coordinates.Longitude= dynamicResult.lon;
return coordinates;
}
public string GetRequest(string url) {
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
request.AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate;
request.UserAgent = @"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.106 Safari/537.36";
using (HttpWebResponse response = (HttpWebResponse)request.GetResponse())
using (Stream stream = response.GetResponseStream())
using (StreamReader reader = new StreamReader(stream))
{
return reader.ReadToEnd();
}
}
public class Coordinates {
public double Longitude { get; set; }
public double Latitude { get; set; }
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.