java servlet手機app訪問接口(三)高德地圖云存儲及檢索
這篇關于高德地圖的隨筆內(nèi)容會多一點,
一、業(yè)務說明
對應APP業(yè)務中的成員有兩類,一是服務人員,二是被服務人員, 主要實現(xiàn)功能, 對APP中的服務人員位置進行時時定位, 然后通過被服務人員登錄APP時提供的一個經(jīng)緯度來計算服務人員與被服務人員之間的距離 單位m。
下面是整個詳細流程,從創(chuàng)建高德對應應用(這里注冊我就不說了)------最后完成此功能。
二、創(chuàng)建servlet對應的高德地圖應用,創(chuàng)建自己的云圖數(shù)據(jù)庫表
注冊帳號后登錄點擊右上角的控制臺,會出現(xiàn)下面這個界面,我截圖

這里當然是我已經(jīng)注冊好了的界面,如果沒注冊進來就一個 button 獲取key,這里你直接點進去,就可以創(chuàng)建你的應用了,應用名稱隨便取,由于我們這里是servlet來處理
相關的業(yè)務,所以選項為Web服務API, 這里你點擊獲取key就會出現(xiàn)下面的截圖

這一步完成,后我們就可以去創(chuàng)建我們要的云圖表了,進入控制臺,選擇鼠標移到我的數(shù)據(jù),然后選擇下面的數(shù)據(jù)管理臺(Web)進入增加云圖表界面

下面是進入后的截圖,這個截圖完了我就直接使用文字講解了。

上面這個截圖是我創(chuàng)建好的結果,這里我們需要先點擊右上角的 數(shù)據(jù)模版下載,將模版下載下來之后,修改相應的數(shù)據(jù),增加自己需要的字段后,然后點新建地圖將
修改后的模版導入到云圖庫中去,這個模版其實就是一個EXCEL導出的數(shù)據(jù)庫表。下面我直接截取我創(chuàng)建的表,我這個表增加了兩個字段,并且將一個字段設置成了索引字段。

記得紅色的字段名稱必須保留(內(nèi)容可以隨便修改),那是系統(tǒng)模版自帶的,后面兩個黑色的字段是自己增加的,可以隨意修改,即使你將它上傳到了高德云圖服務器之后也是可以改的。
上傳上面的表后,你再打開之前 數(shù)據(jù)管理(WEB)就會出現(xiàn)之前一張地圖的界面了,左邊有一張地圖方塊出現(xiàn),你點進去,就能看到你上傳人員的詳細信息,以及通過上傳的經(jīng)緯度在地圖上展示的 黃色五角星標識。下面有截圖

這個表中顯示的字段是我修改過的,不是剛才Excel中上傳的,點擊欄中的標題可以進行一系列的設置,這個我就不詳細說了,
只說下索引字段的設置,

進去后我選擇是 篩選排序索引-->篩選排序索引就是對用戶自己新增加的字段設置一個篩選條件。
我這里使用的是上面云圖中截圖的用戶類型,它的作用我也給各位截下圖。

到這一步我們整個創(chuàng)建云圖及上傳的步驟就完成了。。。接下去我會講調(diào)用的方法。
二、servlet查詢云圖庫的請求方法
1、先貼上開發(fā)者文檔地址:
http://lbs.amap.com/yuntu/reference/cloudsearch/ 這個我建議自己還是去看下
這里servlet使用的是云檢索API, 對應APP使用的是云存儲API,也許明天會增加一篇關于IOS客戶端對應這個接口的時時定位文章。
下面是拼接的URL格式,直接在URL中輸入刷新可以已GET方式獲取相關數(shù)據(jù)。
http://yuntuapi.amap.com/datasearch/local?tableid=568bd32b305a2a31f604c650&city=北京&keywords=%20&filter=type:服務人員limit=15&page=1&key=? (這里的參數(shù) KEY這些都是你自己的)
下面是封裝的請求方法代碼
package Helper;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.net.URL;
import java.net.URLConnection;
import java.util.List;
import java.util.Map;
public class HttpRequest {
/**
* 向指定URL發(fā)送GET方法的請求
*
* @param url
* 發(fā)送請求的URL
* @param param
* 請求參數(shù),請求參數(shù)應該是 name1=value1&name2=value2 的形式。
* @return URL 所代表遠程資源的響應結果
*/
public static String sendGet(String url, String param) {
String result = "";
BufferedReader in = null;
try {
String urlNameString = url + "?" + param;
URL realUrl = new URL(urlNameString);
// 打開和URL之間的連接
URLConnection connection = realUrl.openConnection();
// 設置通用的請求屬性
connection.setRequestProperty("accept", "*/*");
connection.setRequestProperty("connection", "Keep-Alive");
connection.setRequestProperty("user-agent",
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
// 建立實際的連接
connection.connect();
// 獲取所有響應頭字段
Map<String, List<String>> map = connection.getHeaderFields();
// 遍歷所有的響應頭字段
for (String key : map.keySet()) {
System.out.println(key + "--->" + map.get(key));
}
// 定義 BufferedReader輸入流來讀取URL的響應
in = new BufferedReader(new InputStreamReader(
connection.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
result += line;
}
} catch (Exception e) {
System.out.println("發(fā)送GET請求出現(xiàn)異常!" + e);
e.printStackTrace();
}
// 使用finally塊來關閉輸入流
finally {
try {
if (in != null) {
in.close();
}
} catch (Exception e2) {
e2.printStackTrace();
}
}
return result;
}
/**
* 向指定 URL 發(fā)送POST方法的請求
*
* @param url
* 發(fā)送請求的 URL
* @param param
* 請求參數(shù),請求參數(shù)應該是 name1=value1&name2=value2 的形式。
* @return 所代表遠程資源的響應結果
*/
public static String sendPost(String url, String param) {
PrintWriter out = null;
BufferedReader in = null;
String result = "";
try {
URL realUrl = new URL(url);
// 打開和URL之間的連接
URLConnection conn = realUrl.openConnection();
// 設置通用的請求屬性
conn.setRequestProperty("accept", "*/*");
conn.setRequestProperty("connection", "Keep-Alive");
conn.setRequestProperty("user-agent",
"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
// 發(fā)送POST請求必須設置如下兩行
conn.setDoOutput(true);
conn.setDoInput(true);
// 獲取URLConnection對象對應的輸出流
out = new PrintWriter(conn.getOutputStream());
// 發(fā)送請求參數(shù)
out.print(param);
// flush輸出流的緩沖
out.flush();
// 定義BufferedReader輸入流來讀取URL的響應
in = new BufferedReader(
new InputStreamReader(conn.getInputStream()));
String line;
while ((line = in.readLine()) != null) {
result += line;
}
} catch (Exception e) {
System.out.println("發(fā)送 POST 請求出現(xiàn)異常!"+e);
e.printStackTrace();
}
//使用finally塊來關閉輸出流、輸入流
finally{
try{
if(out!=null){
out.close();
}
if(in!=null){
in.close();
}
}
catch(IOException ex){
ex.printStackTrace();
}
}
try {
result= new String(result.getBytes("ISO8859-1"),"UTF-8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
}
}
下面是請求方法
String mapParameter=new String("tableid=568bd32b305a2a31f604c650&city=北京&keywords=%20&filter=type:按摩師limit=15&page=1&key=?").getBytes("ISO8859-1"),"UTF-8");
String returnResult=HttpRequest.sendPost("http://yuntuapi.amap.com/datasearch/local", mapParameter);
out.println("<script> alert("+returnResult+");</script>");

這里我們查詢的篩選條件就是我們自己創(chuàng)建的字段(并且它被我們設置成了索引字段) type:按摩師------------------上面的_updatetime前面的字段都是我們數(shù)據(jù)庫中放的數(shù)據(jù),后面的都是通過傳的經(jīng)緯度查詢出來的真實數(shù)據(jù),但是在真正使用時用時,這些數(shù)據(jù)都是 App端往里面增加的,而且APP還需要傳當前定位的城市名稱給Servlet,所以這里的數(shù)據(jù)都是錯的。
三、servlet計算兩個經(jīng)緯度間的距離
這里就是servlet通過經(jīng)緯度計算被服務人員與服務人員的距離,這里其實是一對多的關系。一個被 被服務人員可以對應N個提供服務的人員。 被服務人員的所在位置經(jīng)緯度會去匹配所有此次查詢出的服務人員的經(jīng)緯度,計算出距離。
下面貼計算距離的方法,這個是一個公用的方法各大地圖都適用。
public static double getDistance(LatLng start,LatLng end){
double lat1 = (Math.PI/180)*start.latitude;
double lat2 = (Math.PI/180)*end.latitude;
double lon1 = (Math.PI/180)*start.longitude;
double lon2 = (Math.PI/180)*end.longitude;
double R = 6371;
double d = Math.acos(Math.sin(lat1)*Math.sin(lat2)+Math.cos(lat1)*Math.cos(lat2)*Math.cos(lon2-lon1))*R;
return d*1000;
}
參數(shù)中的LatLng 你可以自己創(chuàng)建一個類,里面包含兩個字段都是double類型。一個代表精度,一個代表緯度。
使用這個方法產(chǎn)生的流程:當用戶打開服務人員的APP界面時,請求了讀取服務人員列表的接口,這時候SERVLET就需要查詢一次高德云圖里面的服務人員信息,可以限制查詢條數(shù),然后查詢出來,循環(huán)每條數(shù)據(jù)中的經(jīng)緯度與使用被服務人員打開APP界面?zhèn)鞯慕?jīng)緯度,匹配計算出相對距離。 明天也許會發(fā)布一篇IOS的隨筆,就對應這個接口,主要貼在IOS上實現(xiàn)的時時定位傳云圖數(shù)據(jù)庫的代碼。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- java servlet手機app訪問接口(二)短信驗證
- java servlet手機app訪問接口(一)數(shù)據(jù)加密傳輸驗證
- 淺析javax.servlet.Servlet,ServletContext接口
- java后臺調(diào)用HttpURLConnection類模擬瀏覽器請求實例(可用于接口調(diào)用)
- java線程之使用Runnable接口創(chuàng)建線程的方法
- java比較器Comparable接口與Comaprator接口的深入分析
- Java中實現(xiàn)Comparator接口和用法實例(簡明易懂)
- App登陸java后臺處理和用戶權限驗證
- Java實現(xiàn)爬蟲給App提供數(shù)據(jù)(Jsoup 網(wǎng)絡爬蟲)
- 教你構建第一個Java Applet程序
相關文章
Java?從json提取數(shù)組并轉(zhuǎn)換為list的操作方法
這篇文章主要介紹了Java?從json提取出數(shù)組并轉(zhuǎn)換為list,使用getJSONArray()獲取到jsonarray后,再將jsonArray轉(zhuǎn)換為字符串,最后將字符串解析為List列表,本文通過實例代碼給大家詳細講解,需要的朋友可以參考下2022-10-10
Java編程redisson實現(xiàn)分布式鎖代碼示例
這篇文章主要介紹了Java編程redisson實現(xiàn)分布式鎖代碼示例,小編覺得還是比較不錯的,這里給大家分享下,供需要的朋友參考。2017-10-10
java多線程之并發(fā)工具類CountDownLatch,CyclicBarrier和Semaphore
這篇文章主要為大家介紹了java并發(fā)工具類CountDownLatch,CyclicBarrier和Semaphore ,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12
Java Socket使用加密協(xié)議進行傳輸對象的方法
這篇文章主要介紹了Java Socket使用加密協(xié)議進行傳輸對象的方法,結合實例形式分析了java socket加密協(xié)議相關接口與類的調(diào)用方法,以及服務器、客戶端實現(xiàn)技巧,需要的朋友可以參考下2017-06-06
SpringBoot中自定義注解實現(xiàn)參數(shù)非空校驗的示例
這篇文章主要介紹了SpringBoot中自定義注解實現(xiàn)參數(shù)非空校驗,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-11-11

