java servlet手機app訪問接口(三)高德地圖云存儲及檢索
這篇關(guān)于高德地圖的隨筆內(nèi)容會多一點,
一、業(yè)務(wù)說明
對應(yīng)APP業(yè)務(wù)中的成員有兩類,一是服務(wù)人員,二是被服務(wù)人員, 主要實現(xiàn)功能, 對APP中的服務(wù)人員位置進(jìn)行時時定位, 然后通過被服務(wù)人員登錄APP時提供的一個經(jīng)緯度來計算服務(wù)人員與被服務(wù)人員之間的距離 單位m。
下面是整個詳細(xì)流程,從創(chuàng)建高德對應(yīng)應(yīng)用(這里注冊我就不說了)------最后完成此功能。
二、創(chuàng)建servlet對應(yīng)的高德地圖應(yīng)用,創(chuàng)建自己的云圖數(shù)據(jù)庫表
注冊帳號后登錄點擊右上角的控制臺,會出現(xiàn)下面這個界面,我截圖
這里當(dāng)然是我已經(jīng)注冊好了的界面,如果沒注冊進(jìn)來就一個 button 獲取key,這里你直接點進(jìn)去,就可以創(chuàng)建你的應(yīng)用了,應(yīng)用名稱隨便取,由于我們這里是servlet來處理
相關(guān)的業(yè)務(wù),所以選項為Web服務(wù)API, 這里你點擊獲取key就會出現(xiàn)下面的截圖
這一步完成,后我們就可以去創(chuàng)建我們要的云圖表了,進(jìn)入控制臺,選擇鼠標(biāo)移到我的數(shù)據(jù),然后選擇下面的數(shù)據(jù)管理臺(Web)進(jìn)入增加云圖表界面
下面是進(jìn)入后的截圖,這個截圖完了我就直接使用文字講解了。
上面這個截圖是我創(chuàng)建好的結(jié)果,這里我們需要先點擊右上角的 數(shù)據(jù)模版下載,將模版下載下來之后,修改相應(yīng)的數(shù)據(jù),增加自己需要的字段后,然后點新建地圖將
修改后的模版導(dǎo)入到云圖庫中去,這個模版其實就是一個EXCEL導(dǎo)出的數(shù)據(jù)庫表。下面我直接截取我創(chuàng)建的表,我這個表增加了兩個字段,并且將一個字段設(shè)置成了索引字段。
記得紅色的字段名稱必須保留(內(nèi)容可以隨便修改),那是系統(tǒng)模版自帶的,后面兩個黑色的字段是自己增加的,可以隨意修改,即使你將它上傳到了高德云圖服務(wù)器之后也是可以改的。
上傳上面的表后,你再打開之前 數(shù)據(jù)管理(WEB)就會出現(xiàn)之前一張地圖的界面了,左邊有一張地圖方塊出現(xiàn),你點進(jìn)去,就能看到你上傳人員的詳細(xì)信息,以及通過上傳的經(jīng)緯度在地圖上展示的 黃色五角星標(biāo)識。下面有截圖
這個表中顯示的字段是我修改過的,不是剛才Excel中上傳的,點擊欄中的標(biāo)題可以進(jìn)行一系列的設(shè)置,這個我就不詳細(xì)說了,
只說下索引字段的設(shè)置,
進(jìn)去后我選擇是 篩選排序索引-->篩選排序索引就是對用戶自己新增加的字段設(shè)置一個篩選條件。
我這里使用的是上面云圖中截圖的用戶類型,它的作用我也給各位截下圖。
到這一步我們整個創(chuàng)建云圖及上傳的步驟就完成了。。。接下去我會講調(diào)用的方法。
二、servlet查詢云圖庫的請求方法
1、先貼上開發(fā)者文檔地址:
http://lbs.amap.com/yuntu/reference/cloudsearch/ 這個我建議自己還是去看下
這里servlet使用的是云檢索API, 對應(yīng)APP使用的是云存儲API,也許明天會增加一篇關(guān)于IOS客戶端對應(yīng)這個接口的時時定位文章。
下面是拼接的URL格式,直接在URL中輸入刷新可以已GET方式獲取相關(guān)數(shù)據(jù)。
http://yuntuapi.amap.com/datasearch/local?tableid=568bd32b305a2a31f604c650&city=北京&keywords=%20&filter=type:服務(wù)人員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ù)應(yīng)該是 name1=value1&name2=value2 的形式。 * @return URL 所代表遠(yuǎn)程資源的響應(yīng)結(jié)果 */ 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(); // 設(shè)置通用的請求屬性 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(); // 獲取所有響應(yīng)頭字段 Map<String, List<String>> map = connection.getHeaderFields(); // 遍歷所有的響應(yīng)頭字段 for (String key : map.keySet()) { System.out.println(key + "--->" + map.get(key)); } // 定義 BufferedReader輸入流來讀取URL的響應(yīng) 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塊來關(guān)閉輸入流 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ù)應(yīng)該是 name1=value1&name2=value2 的形式。 * @return 所代表遠(yuǎn)程資源的響應(yīng)結(jié)果 */ 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(); // 設(shè)置通用的請求屬性 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請求必須設(shè)置如下兩行 conn.setDoOutput(true); conn.setDoInput(true); // 獲取URLConnection對象對應(yīng)的輸出流 out = new PrintWriter(conn.getOutputStream()); // 發(fā)送請求參數(shù) out.print(param); // flush輸出流的緩沖 out.flush(); // 定義BufferedReader輸入流來讀取URL的響應(yīng) 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塊來關(guān)閉輸出流、輸入流 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)建的字段(并且它被我們設(shè)置成了索引字段) type:按摩師------------------上面的_updatetime前面的字段都是我們數(shù)據(jù)庫中放的數(shù)據(jù),后面的都是通過傳的經(jīng)緯度查詢出來的真實數(shù)據(jù),但是在真正使用時用時,這些數(shù)據(jù)都是 App端往里面增加的,而且APP還需要傳當(dāng)前定位的城市名稱給Servlet,所以這里的數(shù)據(jù)都是錯的。
三、servlet計算兩個經(jīng)緯度間的距離
這里就是servlet通過經(jīng)緯度計算被服務(wù)人員與服務(wù)人員的距離,這里其實是一對多的關(guān)系。一個被 被服務(wù)人員可以對應(yīng)N個提供服務(wù)的人員。 被服務(wù)人員的所在位置經(jīng)緯度會去匹配所有此次查詢出的服務(wù)人員的經(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)生的流程:當(dāng)用戶打開服務(wù)人員的APP界面時,請求了讀取服務(wù)人員列表的接口,這時候SERVLET就需要查詢一次高德云圖里面的服務(wù)人員信息,可以限制查詢條數(shù),然后查詢出來,循環(huán)每條數(shù)據(jù)中的經(jīng)緯度與使用被服務(wù)人員打開APP界面?zhèn)鞯慕?jīng)緯度,匹配計算出相對距離。 明天也許會發(fā)布一篇IOS的隨筆,就對應(yīng)這個接口,主要貼在IOS上實現(xiàn)的時時定位傳云圖數(shù)據(jù)庫的代碼。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 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后臺處理和用戶權(quán)限驗證
- Java實現(xiàn)爬蟲給App提供數(shù)據(jù)(Jsoup 網(wǎng)絡(luò)爬蟲)
- 教你構(gòu)建第一個Java Applet程序
相關(guān)文章
Java?從json提取數(shù)組并轉(zhuǎn)換為list的操作方法
這篇文章主要介紹了Java?從json提取出數(shù)組并轉(zhuǎn)換為list,使用getJSONArray()獲取到j(luò)sonarray后,再將jsonArray轉(zhuǎn)換為字符串,最后將字符串解析為List列表,本文通過實例代碼給大家詳細(xì)講解,需要的朋友可以參考下2022-10-10Java編程redisson實現(xiàn)分布式鎖代碼示例
這篇文章主要介紹了Java編程redisson實現(xiàn)分布式鎖代碼示例,小編覺得還是比較不錯的,這里給大家分享下,供需要的朋友參考。2017-10-10java多線程之并發(fā)工具類CountDownLatch,CyclicBarrier和Semaphore
這篇文章主要為大家介紹了java并發(fā)工具類CountDownLatch,CyclicBarrier和Semaphore ,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12Java Socket使用加密協(xié)議進(jìn)行傳輸對象的方法
這篇文章主要介紹了Java Socket使用加密協(xié)議進(jìn)行傳輸對象的方法,結(jié)合實例形式分析了java socket加密協(xié)議相關(guān)接口與類的調(diào)用方法,以及服務(wù)器、客戶端實現(xiàn)技巧,需要的朋友可以參考下2017-06-06SpringBoot中自定義注解實現(xiàn)參數(shù)非空校驗的示例
這篇文章主要介紹了SpringBoot中自定義注解實現(xiàn)參數(shù)非空校驗,幫助大家更好的理解和使用springboot框架,感興趣的朋友可以了解下2020-11-11