javaweb实现百度GPS定位接口(经纬度)

百度web GPS定位(经纬度)

注册账号及配置地址

http://lbsyun.baidu.com/apiconsole/key

主类 BaiduWebAPI

import java.util.Map;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Logger;

import com.webber.cm.common.util.HttpClient;
import com.webber.cm.common.util.JsonUtil;

public class BaiduWebAPI {

 static Logger logger = Logger.getLogger(BaiduWebAPI.class);

 // 配置地址:http://lbsyun.baidu.com/apiconsole/key
 private static final String APP_ID = "18**********";
 private static final String AK = "XGXnh8tB7e*******************";

 public static void main(String[] args) {
 //BaiduWebAPI.ipLocation("127.0.0.1");
 BaiduWebAPI.gpsLocation("116.840213","39.196272");
 }

 // GPS接口
 public static String gpsLocation(String lng, String lat) {
 String result = null;
 try {
  String url = "http://api.map.baidu.com/reverse_geocoding/v3/?ak=MY_AK&output=json&coordtype=wgs84ll&location=LAT_VALUE,LNG_VALUE";
  url = url.replace("MY_AK", AK).replace("LNG_VALUE", lng).replace("LAT_VALUE", lat);
  String reqResult = HttpClient.doGet(url);
  System.out.println(reqResult);
  Map<String, Object> map = JsonUtil.parseJSON2Map(reqResult);
  Map ac = (Map) ((Map) map.get("result")).get("addressComponent");
  result = ac.get("city").toString() + ac.get("district").toString();
 } catch (Exception e) {
  logger.error("GPS接口异常:", e);
 }
 logger.info("GPS接口:{lng:" + lng + ",lat:" + lat + ",result:" + result + "}");
 return result;
 }

 // IP接口
 public static String ipLocation(String ip) {
 if(BaiduWebAPI.isLan(ip)) {
  return "内网IP";
 }
 String result = null;
 try {
  String url = "http://api.map.baidu.com/location/ip?ak=MY_AK&ip=IP_VALUE&coor=bd09ll";
  url = url.replace("MY_AK", AK).replace("IP_VALUE", ip);
  String reqResult = decodeUnicode(HttpClient.doGet(url));
  System.out.println(reqResult);
  Map<String, Object> map = JsonUtil.parseJSON2Map(reqResult);
  result=((Map) map.get("content")).get("address").toString();
  result=result.replace("省", "").replace("市", "");
 } catch (Exception e) {
  logger.error("IP接口异常:", e);
 }
 logger.info("IP接口:{ip:" + ip + ",result:" + result + "}");
 return result;
 }

 // unicode转化汉字
 public static String decodeUnicode(final String unicode) {
 StringBuffer string = new StringBuffer();

 String[] hex = unicode.split("\\\\u");

 for (int i = 0; i < hex.length; i++) {

  try {
  // 汉字范围 \u4e00-\u9fa5 (中文)
  if (hex[i].length() >= 4) {// 取前四个,判断是否是汉字
   String chinese = hex[i].substring(0, 4);
   try {
   int chr = Integer.parseInt(chinese, 16);
   boolean isChinese = isChinese((char) chr);
   // 转化成功,判断是否在 汉字范围内
   if (isChinese) {// 在汉字范围内
    // 追加成string
    string.append((char) chr);
    // 并且追加 后面的字符
    String behindString = hex[i].substring(4);
    string.append(behindString);
   } else {
    string.append(hex[i]);
   }
   } catch (NumberFormatException e1) {
   string.append(hex[i]);
   }

  } else {
   string.append(hex[i]);
  }
  } catch (NumberFormatException e) {
  string.append(hex[i]);
  }
 }
 return string.toString();
 }

 /**
 * 判断是否为中文字符
 *
 * @param c
 * @return
 */
 public static boolean isChinese(char c) {
 Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
 if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS
  || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
  || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A
  || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION
  || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION
  || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) {
  return true;
 }
 return false;
 }

 // 是否为局域网
 private static Boolean isLan(String ip) {
    if("127.0.0.1".equals(ip)) {
     return true;
    }

    if (!StringUtils.isEmpty(ip) && ip.length() > 15) {
      ip = ip.substring(0, ip.indexOf(","));
    }
    /*
     * 判断客户单IP地址是否为内网地址
     * 内网IP网段:
     * 10.0.0.0-10.255.255.255
     * 172.16.0.0-172.31.255.255
     * 192.168.0.0-192.168.255.255
     */
    String reg = "^(192\\.168|172\\.(1[6-9]|2\\d|3[0,1]))(\\.(2[0-4]\\d|25[0-5]|[0,1]?\\d?\\d)){2}$|^10(\\.([2][0-4]\\d|25[0-5]|[0,1]?\\d?\\d)){3}$";
    Pattern p = Pattern.compile(reg);
    Matcher matcher = p.matcher(ip);
    return matcher.find();
  }
}

工具类 HttpClient

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;

public class HttpClient {

 public static void main(String[] args) {

 }

 public static String doGet(String httpurl) {
 HttpURLConnection connection = null;
 InputStream is = null;
 BufferedReader br = null;
 String result = null;// 返回结果字符串
 try {
  // 创建远程url连接对象
  URL url = new URL(httpurl);
  // 通过远程url连接对象打开一个连接,强转成httpURLConnection类
  connection = (HttpURLConnection) url.openConnection();
  // 设置连接方式:get
  connection.setRequestMethod("GET");
  // 设置连接主机服务器的超时时间:15000毫秒
  connection.setConnectTimeout(15000);
  // 设置读取远程返回的数据时间:60000毫秒
  connection.setReadTimeout(60000);
  // 发送请求
  connection.connect();
  // 通过connection连接,获取输入流
  if (connection.getResponseCode() == 200) {
  is = connection.getInputStream();
  // 封装输入流is,并指定字符集
  br = new BufferedReader(new InputStreamReader(is, "UTF-8"));
  // 存放数据
  StringBuffer sbf = new StringBuffer();
  String temp = null;
  while ((temp = br.readLine()) != null) {
   sbf.append(temp);
   sbf.append("\r\n");
  }
  result = sbf.toString();
  }
 } catch (MalformedURLException e) {
  e.printStackTrace();
 } catch (IOException e) {
  e.printStackTrace();
 } finally {
  // 关闭资源
  if (null != br) {
  try {
   br.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
  }

  if (null != is) {
  try {
   is.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
  }

  connection.disconnect();// 关闭远程连接
 }

 return result;
 }

 public static String doPost(String httpUrl, String param) {
 HttpURLConnection connection = null;
 InputStream is = null;
 OutputStream os = null;
 BufferedReader br = null;
 String result = null;
 try {
  URL url = new URL(httpUrl);
  // 通过远程url连接对象打开连接
  connection = (HttpURLConnection) url.openConnection();
  // 设置连接请求方式
  connection.setRequestMethod("POST");
  // 设置连接主机服务器超时时间:15000毫秒
  connection.setConnectTimeout(15000);
  // 设置读取主机服务器返回数据超时时间:60000毫秒
  connection.setReadTimeout(60000);

  // 默认值为:false,当向远程服务器传送数据/写数据时,需要设置为true
  connection.setDoOutput(true);
  // 默认值为:true,当前向远程服务读取数据时,设置为true,该参数可有可无
  connection.setDoInput(true);
  // 设置传入参数的格式:请求参数应该是 name1=value1&name2=value2 的形式。
  connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
  // 设置鉴权信息:Authorization: Bearer da3efcbf-0845-4fe3-8aba-ee040be542c0
  connection.setRequestProperty("Authorization", "Bearer da3efcbf-0845-4fe3-8aba-ee040be542c0");
  // 通过连接对象获取一个输出流
  os = connection.getOutputStream();
  // 通过输出流对象将参数写出去/传输出去,它是通过字节数组写出的
  os.write(param.getBytes());
  // 通过连接对象获取一个输入流,向远程读取
  if (connection.getResponseCode() == 200) {

  is = connection.getInputStream();
  // 对输入流对象进行包装:charset根据工作项目组的要求来设置
  br = new BufferedReader(new InputStreamReader(is, "UTF-8"));

  StringBuffer sbf = new StringBuffer();
  String temp = null;
  // 循环遍历一行一行读取数据
  while ((temp = br.readLine()) != null) {
   sbf.append(temp);
   sbf.append("\r\n");
  }
  result = sbf.toString();
  }
 } catch (MalformedURLException e) {
  e.printStackTrace();
 } catch (IOException e) {
  e.printStackTrace();
 } finally {
  // 关闭资源
  if (null != br) {
  try {
   br.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
  }
  if (null != os) {
  try {
   os.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
  }
  if (null != is) {
  try {
   is.close();
  } catch (IOException e) {
   e.printStackTrace();
  }
  }
  // 断开与远程地址url的连接
  connection.disconnect();
 }
 return result;
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • java实现在pdf模板的指定位置插入图片

    本文实例为大家分享了java在pdf模板的指定位置插入图片的具体代码,供大家参考,具体内容如下 java操作pdf有个非常好用的库itextpdf,maven: <dependency> <groupId>com.itextpdf</groupId> <artifactId>itextpdf</artifactId> <version>5.5.6</version> </dependency> <!--

  • java微信开发中的地图定位功能

    页面代码: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+&q

  • 深入理解JVM之Java对象的创建、内存布局、访问定位详解

    本文实例讲述了深入理解JVM之Java对象的创建.内存布局.访问定位.分享给大家供大家参考,具体如下: 对象的创建 一个简单的创建对象语句Clazz instance = new Clazz();包含的主要过程包括了类加载检查.对象分配内存.并发处理.内存空间初始化.对象设置.执行ini方法等. 主要流程如下: 1. 类加载检查 JVM遇到一条new指令时,首先检查这个指令的参数是否能在常量池中定位到一个类的符号引用,并且检查这个符号引用代表的类是否已被加载.解析和初始化过.如果没有,那必须先执

  • Java RandomAccessFile 指定位置实现文件读取与写入

    Java RandomAccessFile 指定位置实现文件读取与写入 RandomAccessFile是属于随机读取类,是可以对文件本身的内容直接随机进行操作的,可以在文件的指定位置的读取和写入内容,这在很多时候都是很方便的. RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了.这些记录的大小不必相同:但是其大小和位置必须是可知的.但是该类仅限于操作文件. RandomAccessFile不属于InputStream和Out

  • 使用IDEA异常断点来定位java.lang.ArrayStoreException的问题

    前言 最近对 base-spring-boot项目进行了升级.在将其用于应用开发中时遇到java.lang.ArrayStoreException的异常导致程序无法启动.平常开发过程中面对这种描述不够清楚,无法定位具体原因的问题该如何处理?本文分享通过使用IDEA异常断点来定位此类问题的方法. 启动程序时抛出如下异常,导致启动失败 org.springframework.beans.factory.BeanCreationException: Error creating bean with n

  • 详解Java编程中统一资源定位符URL的相关使用

    统一资源定位符URL(Uniform Resource Locator)是www客户机访问Internet时用来标识资源的名字和地址.超文本链路由统一资源定位符URL维持.URL的格式是:     <METHOD>://<HOSTNAME:PORT>/<PATH>/<FILE> 其中:Method是传输协议:HOSTNAME是文档和服务器所在的Internet主机名(域名系统中DNS中的点地址);PORT是服务端口号(可省略):PATH是路径名,FILE是文

  • Java 替换word文档文字并指定位置插入图片

    先说下 需要的依赖包 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-excelant</artifactId> <version>3.12</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <arti

  • java selenium元素定位大全

    页面元素定位是自动化中最重要的事情, selenium Webdriver 提供了很多种元素定位的方法.  测试人员应该熟练掌握各种定位方法. 使用最简单,最稳定的定位方法. 阅读目录 自动化测试步骤 定位方法大全 如何定位 通过ID查找元素: By.id() 通过Name查找元素:By.name() 通过TagName查找元素: By.tagName() 通过ClassName 查找元素 By.className 通过LinkText查找元素 By.linkText(); 通过PartialL

  • java使用itext导出PDF文本绝对定位(实现方法)

    jar:itext-4.2.1.jar 在很多公文的落款处都需要绝对定位,所以记录此代码如下: PdfWriter writer = PdfWriter.getInstance(document, new FileOutputStream("test.pdf")); PdfContentByte cb = writer.getDirectContent(); BaseFont bf= BaseFont.createFont("STSong-Light", "

  • java selenium XPath 定位实现方法

    xpath 的定位方法, 非常强大.  使用这种方法几乎可以定位到页面上的任意元素. 阅读目录 什么是xpath xpath定位的缺点 testXpath.html 代码如下 绝对路径定位方式 使用浏览器调试工具,可以直接获取xpath语句 绝对路径的缺点 绝对路径和相对路径的区别 相对路径定位方式 使用索引号定位 使用页面属性定位 模糊定位starts-with关键字 模糊定位contains关键字 text() 函数 文本定位 什么是xpath xpath 是XML Path的简称, 由于H

  • java调用百度定位api服务获取地理位置示例

    复制代码 代码如下: package test; import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.Reader;import java.net.URL;import java.nio.charset.Charset; import org.json.JSONException;imp

随机推荐