利用百度LBS做一个小Demo

简介:
  • 申请ak(即获取密钥

  • 拼写发送http请求的url

    • 譬如这样的调用

    • http://api.map.baidu.com/geocoder/v2/?address=百度大厦&output=json&ak=E4805d16520de693a3fe707cdc962045&callback=showLocation
  • 接收http请求返回的数据

下面看看代码

/**
 * 接口常量
 * @author rex
 *
 */
public interface BaiDuApi {

    /*
     * 根据ip获取信息
     */
    public static final String BD_IP_LOCATION_API = "http://api.map.baidu.com/location/ip";
    
    /*
     *根据城市/经纬度获取信息
     */
    public static final String BD_LOCATION2POINT_API = "http://api.map.baidu.com/geocoder/v2/";
    
    /*
     * 百度lbs ak密钥
     */
    public static final String BD_LBS_AK = "你申请的AK";
    
}

    

/*
 * 百度地图API
 */
public final class BaiDuMapApi {

    private static Map<StringString> params = CollectionUtil.newHashMap();

    private static final List<String> LOCAL_IP = Arrays.asList("127.0.0.1""localhost");

    /*
     * 根据ip获取经纬度
     */
    public static Map<StringString> getPoint(String ip) {
        params.clear();
        Map<StringStringpoint = CollectionUtil.newHashMap();
        if (null != ip && !LOCAL_IP.contains(ip)) {
            params.put("ip", ip);
        }
        params.put("ak", BaiDuApi.BD_LBS_AK);
        params.put("coor""bd09ll");
        String r = HttpKit.get(BaiDuApi.BD_IP_LOCATION_API, params);
        String json = StringUtils.unicodeToString(r);
        Map<StringObjectmap = JSONUtil.json2Map(json);
        Map<StringObject> content = JSONUtil.json2Map(map.get("content").toString());
        Map<StringString> xy = JSONUtil.json2Map(content.get("point").toString());
        point.put("latitude", xy.get("y"));
        point.put("longitude", xy.get("x"));
        return point;
    }

    /*
     * 根据城市和地址获取经纬度
     */
    public static Map<StringString> getPoint(String city, String address) {
        params.clear();
        Map<StringStringpoint = CollectionUtil.newHashMap();
        if (StringUtils.isNotBlank(city) && StringUtils.isNotBlank(address)) {
            params.put("ak", BaiDuApi.BD_LBS_AK);
            params.put("callback""renderOption");
            params.put("output""json");
            params.put("city", city);
            params.put("address", address);
            String r = HttpKit.get(BaiDuApi.BD_LOCATION2POINT_API, params);
            String json = StringUtils.unicodeToString(r.substring(r.indexOf("{"), r.lastIndexOf("}") + 1));
            Map<StringObjectmap = JSONUtil.json2Map(json);
            Map<StringObject> content = JSONUtil.json2Map(map.get("result").toString());
            Map<StringObject> location = JSONUtil.json2Map(content.get("location").toString());
            point.put("latitude", location.get("lat").toString());
            point.put("longitude", location.get("lng").toString());
        }
        return point;
    }

    /*
     * 根据ip获取address
     */
    public static Map<StringString> getAddress(String ip) {
        params.clear();
        Map<StringString> address_detail = CollectionUtil.newHashMap();
        if (null != ip && !LOCAL_IP.contains(ip)) {
            params.put("ip", ip);
        }
        params.put("ak", BaiDuApi.BD_LBS_AK);
        String r = HttpKit.get(BaiDuApi.BD_IP_LOCATION_API, params);
        String json = StringUtils.unicodeToString(r);
        Map<StringObjectmap = JSONUtil.json2Map(json);
        Map<StringObject> content = JSONUtil.json2Map(map.get("content").toString());
        address_detail = JSONUtil.json2Map(content.get("address_detail").toString());
        return address_detail;
    }

    /*
     * 根据经纬度获取详细地址
     */
    public static Map<StringObject> getAddress(String latitude, String longitude) {
        params.clear();
        Map<StringObject> info = CollectionUtil.newHashMap();
        if (StringUtils.isNotBlank(latitude) && StringUtils.isNotBlank(longitude)) {
            params.put("callback""renderReverse");
            params.put("ak", BaiDuApi.BD_LBS_AK);
            params.put("location", latitude + "," + longitude);
            params.put("output""json");
            params.put("pois""0");
            String r = HttpKit.get(BaiDuApi.BD_LOCATION2POINT_API, params);
            String json = StringUtils.unicodeToString(r.substring(r.indexOf("{"), r.lastIndexOf("}") + 1));
            Map<StringObjectmap = JSONUtil.json2Map(json);
            info = JSONUtil.json2Map(map.get("result").toString());
        }
        return info;
    }

}

/*
 * 百度地图API测试
 */
public class Test {

    public static void main(String[] args) {
        //获取地址信息
        Map<StringString> m1 = BaiDuMapApi.getAddress(null);
        System.out.println(m1);
        
        //获取经纬度信息
        Map<StringString> m2 = BaiDuMapApi.getPoint(null);
        System.out.println(m2);
        
        //根据城市获取经纬度
        Map<StringString> m3 = BaiDuMapApi.getPoint("上海市""东方明珠");
        System.out.println(m3);
        
        //根据经纬度获取地址
        Map<StringObject> m4 = BaiDuMapApi.getAddress(m3.get("latitude"), m3.get("longitude"));
        System.out.println(m4);
    }
}

    

{province=上海市, city=上海市, street=district=street_number=city_code=289}
{latitude=31.24916171longitude=121.48789949}
{latitude=31.244750205504longitude=121.50713723717}
{formatted_address=上海市浦东新区陆家嘴环路1388号, business=东外滩,陆家嘴,外滩, cityCode=289location={"lat":31.244750051136,"lng":121.50713723717}, addressComponent={"city":"上海市","district":"浦东新区","province":"上海市","street":"陆家嘴环路","street_number":"1388号"}}

目录
相关文章
|
6月前
|
JavaScript 定位技术
Vue中使用百度地图demo Vue Baidu Map(vue-baidu-map)设置窗口信息
Vue中使用百度地图demo Vue Baidu Map(vue-baidu-map)设置窗口信息
452 0
|
6月前
|
存储 数据可视化 数据库
InfluxData【付诸实践 01】Windows环境部署Telegraf+Influxdb+Grafana安装及使用配置(含百度云盘资源+demo脚本)
InfluxData【付诸实践 01】Windows环境部署Telegraf+Influxdb+Grafana安装及使用配置(含百度云盘资源+demo脚本)
200 0
|
移动开发 JavaScript 前端开发
地图开发笔记(一):百度地图介绍、使用和Qt内嵌地图Demo
地图开发笔记(一):百度地图介绍、使用和Qt内嵌地图Demo
地图开发笔记(一):百度地图介绍、使用和Qt内嵌地图Demo
|
JavaScript API 定位技术
百度地图api 常用demo
功能一:获取map地图窗口的可视区域: var map = new BMap.Map("allmap");            // 创建Map实例 map.centerAndZoom(new BMap.Point(116.4035,39.915), 14);  //初始化时,即可设置中心点和地图缩放级别。
1365 0
|
定位技术 Android开发 Java
|
API 定位技术 JavaScript
百度地图API开发demo地址
此次开发的GPS车辆人员定位系统中,涉及到的开发内容重点有: 1、车辆实时定位:要求页面每10s刷新一次,显示车辆最后一次位置,地图上的所有车辆点击可查看车辆的实时运行信息,如速度、方向以及基础信息,选择某个车辆可以开始跟踪该车辆的行驶路线。
2108 0
|
Web App开发 存储 JavaScript
百度mobile UI组件GMU demo学习1-结构和初始化
移动web现在已经是zepto的天下,但是一直找不到合适UI库,找了一段时间,终于找到了百度的ui库gum和inter 的 appframework UI库 相比之下,百度的UI库更接地气,配合百度强大的用户群,在各种山寨机和山寨浏览器上也可以取得不错的体验,最近终于有时间学习下这个ui库希望等一步一步进入移动web开发领域。
1510 0