C#的百度地图开发(一)发起HTTP请求

原文:C#的百度地图开发(一)发起HTTP请求

百度地图的开发文档中给出了很多的事例,而当用到具体的语言来开发时,又会有些差异。我是使用C#来开发的。在获取相应的数据时,需要通过URL传值,然后获取相应的返回值(这一点很多平台的开发都是如此:比如微信的企业号)。所以我们第一步要解决的就是如何发起URL请求。

如果是在前端,我们可以很轻易的发起URL请求,就是在浏览器的地址栏中输入URL即可,那么在C#的后台要如何发起请求呢?来看下面的代码:

  1. /// <summary>
  2. /// 向指定URL发起请求(可用于远程发送数据)
  3. /// </summary>
  4. /// <param name="url"></param>
  5. /// <param name="data">发送的数据</param>
  6. /// <param name="method"></param>
  7. /// <returns></returns>
  8. public static String RequestUrl(String url, byte[] data, String method = "POST")
  9. {
  10. try
  11. {
  12. WebRequest request = WebRequest.Create(url);
  13. request.Method = method;
  14. request.ContentType = "application/x-www-form-urlencoded";
  15. if (data != null && data.Length > 0)
  16. {
  17. request.ContentLength = data.Length;
  18. Stream newStream = request.GetRequestStream();
  19. newStream.Write(data, 0, data.Length);
  20. newStream.Close();
  21. }
  22. else
  23. {
  24. request.ContentLength = 0;
  25. }
  26. WebResponse response = request.GetResponse();
  27. Stream stream = response.GetResponseStream();
  28. MemoryStream ms = new MemoryStream();
  29. long ChunkSize = 1024;
  30. byte[] buffer = new byte[ChunkSize];
  31. long dataLengthToRead = response.ContentLength;//获取响应数据的总大小
  32. while (dataLengthToRead > 0)
  33. {
  34. int lengthRead = stream.Read(buffer, 0, Convert.ToInt32(ChunkSize));//读取的大小
  35. ms.Write(buffer, 0, lengthRead);
  36. dataLengthToRead = dataLengthToRead - lengthRead;
  37. }
  38. stream.Close();
  39. response.Close();
  40. string responseText = Encoding.UTF8.GetString(ms.ToArray());
  41. return responseText;
  42. }
  43. catch (Exception ex)
  44. {
  45. return ex.Message;
  46. }
  47. }

注:

(1).由WebRequest发起请求,使用WebResponse来获取响应的数据。

(2).参数URL可以含有参数,与一般的GET方法添加的参数一样。

(3).如果使用POST方法,还可以将data数据发送过去。如果data为null时,类似于GET方法。使用POST,可以实现跨域的数据传送(只需要将URL指向一般处理程序的URL即可),比如文件传输。

下面是测试代码

  1. /// <summary>
  2. /// 百度地图API的KEY
  3. /// </summary>
  4. public const string MAP_KEY_BAI_DU = "XXXXXXXXXXXXX";
  5. /// <summary>
  6. /// 转换成百度坐标的URL模板.
  7. /// 参数1:百度地图API的KEY。
  8. /// 参数2:坐标数据。坐标(经度,纬度)的经度和纬度以逗号隔开,坐标之间以分号隔开。
  9. /// 参数3:源坐标的类型。
  10. /// 参数4:结果坐标的类型。
  11. /// </summary>
  12. public const string TRANSFORM_COORDINATE_URL_TEMPLEATE =
  13. "http://api.map.baidu.com/geoconv/v1/?ak={0}&coords={1}&from={2}&to={3}&";
  1. protected void btnTest_Click(object sender, EventArgs e)
  2. {
  3. String coordinates = "39.92,116.46;40.13,117.10";
  4. String transformUrl = String.Format(BaiduMap.TRANSFORM_COORDINATE_URL_TEMPLEATE,
  5. BaiduMap.MAP_KEY_BAI_DU,
  6. coordinates,
  7. (int)MapCoordinateType.GOOGLE_SOSO_ALIYUN_MAPABC_AMAP,
  8. (int)MapCoordinateType.BAIDU);
  9. String transformResponsText = RequestHelper.RequestUrl(transformUrl, null);
  10. Alert.Show(transformResponsText);
  11. }
  1. public enum MapCoordinateType
  2. {
  3. /// <summary>
  4. /// 未知类型
  5. /// </summary>
  6. UNKNOWN = 0,
  7. /// <summary>
  8. ///GPS设备获取的角度坐标;
  9. /// </summary>
  10. GPS_ANGLE = 1,
  11. /// <summary>
  12. ///GPS获取的米制坐标、sogou地图所用坐标;
  13. /// </summary>
  14. GPS_METER_OR_SOGOU = 2,
  15. /// <summary>
  16. ///google地图、soso地图、aliyun地图、mapabc地图和amap地图所用坐标
  17. /// </summary>
  18. GOOGLE_SOSO_ALIYUN_MAPABC_AMAP = 3,
  19. /// <summary>
  20. /// google地图、soso地图、aliyun地图、mapabc地图和amap地图所用坐标对应的米制坐标
  21. /// </summary>
  22. GOOGLE_SOSO_ALIYUN_MAPABC_AMAP_METER = 4,
  23. /// <summary>
  24. ///百度地图采用的经纬度坐标
  25. /// </summary>
  26. BAIDU = 5,
  27. /// <summary>
  28. ///百度地图采用的米制坐标
  29. /// </summary>
  30. BAIDU_METER = 6,
  31. /// <summary>
  32. /// mapbar地图坐标
  33. /// </summary>
  34. MAPBAR = 7,
  35. /// <summary>
  36. /// 51地图坐标
  37. /// </summary>
  38. _51 = 8
  39. }

注:

(1).百度地图的KEY需要申请

(2).MapCoordinateType是根据官方文档封装的一个枚举类型

(3).该测试方法的主要功能,是将非百度坐标转换成百度坐标。因为如果不是百度的坐标(比如微信中获取的坐标数据),再用百度的地图来定位,会相差极大,有的可能是十万八千里,所以必须转换后才可使用。

下面测试的结果

C#的百度地图开发(一)发起HTTP请求

可以看到返回的是JSON数据,那要如何把这个JSON转换成C#的类呢?请看后一文《C#的百度地图开发(二)转换JSON数据为相应的类》。

上一篇:Unity Ragdoll 实现死亡效果 心得+坑点总结


下一篇:指数循环节 求A的B次方模C