package com.wrx.mng.util;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
import java.net.URL;
import java.net.URLConnection;
import java.util.HashMap;
import java.util.Map;
import net.sf.json.JSONObject;
public class EntCoordSyncJob {
public static void main(String[] args){
/*把代码中的ak值(红色字部分)更改为你自己的ak值,在百度地图API中注册一下就有。
调用方式:*/
Map<String,Double> map=EntCoordSyncJob.getLngAndLat("杭州市长河路");
System.out.println("经度:"+map.get("lng")+"---纬度:"+map.get("lat"));
}
/**
* 百度地图通过地址来获取经纬度,传入参数address
* @param address
* @return
*/
public static Map<String,Double> getLngAndLat(String addr){
String address = "";
try {
address = java.net.URLEncoder.encode(addr,"UTF-8");
} catch (UnsupportedEncodingException e1) {
e1.printStackTrace();
}
Map<String,Double> map=new HashMap<String, Double>();
String url = "http://api.map.baidu.com/geocoder?address="+address+"&output=json&ak=秘钥";
String json = loadJSON(url);
JSONObject obj = JSONObject.fromObject(json);
if(obj.get("status").toString().equals("OK")){
double lng=obj.getJSONObject("result").getJSONObject("location").getDouble("lng");
double lat=obj.getJSONObject("result").getJSONObject("location").getDouble("lat");
map.put("lng", lng);
map.put("lat", lat);
System.out.println("经度:" + lng + "--- 纬度:" + lat);
}else{
System.out.println("未找到相匹配的经纬度!");
}
return map;
}
public static String loadJSON (String url) {
StringBuilder json = new StringBuilder();
try {
URL oracle = new URL(url);
URLConnection yc = oracle.openConnection();
BufferedReader in = new BufferedReader(new InputStreamReader(
yc.getInputStream()));
String inputLine = null;
while ( (inputLine = in.readLine()) != null) {
json.append(inputLine);
}
in.close();
} catch (Exception e) {
}
return json.toString();
}
}