利用高德地图根据详细地址获取经纬度(工具类)

废话不多说,直接上代码:

package org.changneng.framework.frameworkweb.utils;

import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLEncoder;

public class HttpURLConnectionTest {
	public static final String GET_URL = "http://restapi.amap.com/v3/geocode/geo?key=389880a06e3f893ea46036f030c94700&s=rsv3&city=35"
            + "&address=平凉市庄浪县朱店镇柳李村三社";
    public static final String POST_URL = "http://restapi.amap.com/v3/geocode/geo?key=389880a06e3f893ea46036f030c94700&s=rsv3&city=35"
            + "&address=平凉市庄浪县朱店镇柳李村三社";
    /**
     * 接口调用 GET
     */
    public static void httpURLConectionGET() {
        try {
            URL url = new URL(GET_URL);    // 把字符串转换为URL请求地址
           HttpURLConnection connection = (HttpURLConnection) url.openConnection();// 打开连接
           connection.connect();// 连接会话
           // 获取输入流
           BufferedReader br = new BufferedReader(new InputStreamReader(connection.getInputStream()));
            String line;
            StringBuilder sb = new StringBuilder();
            while ((line = br.readLine()) != null) {// 循环读取流
               sb.append(line);
            }
            br.close();// 关闭流
           connection.disconnect();// 断开连接
           System.out.println("Get=="+sb.toString());
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("失败!");
        }
    }

    /**
     * 接口调用  POST
     */
    public static void httpURLConnectionPOST () {
        try {
            URL url = new URL(POST_URL);

            // 将url 以 open方法返回的urlConnection  连接强转为HttpURLConnection连接  (标识一个url所引用的远程对象连接)
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();// 此时cnnection只是为一个连接对象,待连接中

            // 设置连接输出流为true,默认false (post 请求是以流的方式隐式的传递参数)
            connection.setDoOutput(true);

            // 设置连接输入流为true
            connection.setDoInput(true);

            // 设置请求方式为post
            connection.setRequestMethod("POST");

            // post请求缓存设为false
            connection.setUseCaches(false);

            // 设置该HttpURLConnection实例是否自动执行重定向
           connection.setInstanceFollowRedirects(true);

            // 设置请求头里面的各个属性 (以下为设置内容的类型,设置为经过urlEncoded编码过的from参数)
            // application/x-javascript text/xml->xml数据 
            //application/x-javascript->json对象  
            //application/x-www-form-urlencoded->表单数据
            //这是重点^_^
           connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");

            // 建立连接 (请求未开始,直到connection.getInputStream()方法调用时才发起,以上各个参数设置需在此方法之前进行)
            connection.connect();

            // 创建输入输出流,用于往连接里面输出携带的参数,(输出内容为?后面的内容)
            DataOutputStream dataout = new DataOutputStream(connection.getOutputStream());
            String parm = "storeId=" + URLEncoder.encode("32", "utf-8"); //URLEncoder.encode()方法  为字符串进行编码

            // 将参数输出到连接
           dataout.writeBytes(parm);

            // 输出完成后刷新并关闭流
           dataout.flush();
            dataout.close(); // 重要且易忽略步骤 (关闭流,切记!) 

            System.out.println(connection.getResponseCode());

            // 连接发起请求,处理服务器响应  (从连接获取到输入流并包装为bufferedReader)
            BufferedReader bf = new BufferedReader(new InputStreamReader(connection.getInputStream())); 
            String line;
            StringBuilder sb = new StringBuilder(); // 用来存储响应数据

            // 循环读取流,若不到结尾处
           while ((line = bf.readLine()) != null) {
                sb.append(bf.readLine());
            }
            bf.close();    // 重要且易忽略步骤 (关闭流,切记!) 
            connection.disconnect(); // 销毁连接
           System.out.println("Post=="+sb.toString());

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
//         httpURLConectionGET();
        httpURLConectionGET();
        httpURLConnectionPOST();
    }
} 


  • 5
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现在vue中点击高德地图获取经纬度详细地址,可以按照以下步骤进行: 1. 在vue项目中安装 `vue-amap` 插件。可以使用npm安装,命令如下: ``` npm install vue-amap --save ``` 2. 在 `main.js` 中引入 `vue-amap` 并进行初始化配置。 ```javascript import VueAMap from 'vue-amap'; Vue.use(VueAMap); VueAMap.initAMapApiLoader({ key: 'your amap key', plugin: ['AMap.Geocoder'] }); ``` 其中 `your amap key` 是你的高德地图开发者Key,需要在高德开放平台上申请。 3. 在组件中引入 `Amap` 组件,并在 `mounted` 钩子函数中进行地图初始化以及监听地图点击事件。 ```vue <template> <div> <div id="map" style="height: 500px;"></div> </div> </template> <script> export default { data() { return { map: null, geocoder: null, marker: null, address: '', lnglat: null } }, mounted() { this.initMap(); this.initGeocoder(); this.addMapClickEvent(); }, methods: { initMap() { this.map = new AMap.Map('map', { zoom: 13, center: [116.397428, 39.90923] }); }, initGeocoder() { this.geocoder = new AMap.Geocoder({ city: "北京" }); }, addMapClickEvent() { let self = this; this.map.on('click', function(e) { self.lnglat = e.lnglat; self.getAddressByLngLat(); self.addMarker(); }); }, getAddressByLngLat() { let self = this; this.geocoder.getAddress(this.lnglat, function(status, result) { if (status === 'complete' && result.regeocode) { self.address = result.regeocode.formattedAddress; } }); }, addMarker() { if (this.marker) { this.map.remove(this.marker); } this.marker = new AMap.Marker({ position: this.lnglat, }); this.map.add(this.marker); } } } </script> ``` 4. 在 `data` 中定义需要用到的变量,如 `map` 表示地图对象、 `geocoder` 表示逆地址解析对象、 `marker` 表示标记点对象、 `address` 表示详细地址、 `lnglat` 表示经纬度。 5. 在 `mounted` 钩子函数中,先调用 `initMap` 方法初始化地图对象,然后调用 `initGeocoder` 方法初始化逆地址解析对象,最后调用 `addMapClickEvent` 方法监听地图点击事件。 6. 在 `addMapClickEvent` 方法中,使用 `map.on('click', function(e) {...})` 监听地图点击事件,并在回调函数中获取点击位置的经纬度并保存到 `lnglat` 变量中,然后调用 `getAddressByLngLat` 方法通过经纬度获取详细地址,并调用 `addMarker` 方法在地图上添加标记点。 7. 在 `getAddressByLngLat` 方法中,调用逆地址解析对象的 `getAddress` 方法,根据经纬度获取详细地址,并将地址保存到 `address` 变量中。 8. 在 `addMarker` 方法中,先判断是否已有标记点,如果有则先移除旧的标记点,然后创建新的标记点并添加到地图上。 9. 最后,在模板中使用 `id="map"` 定义地图容器,并添加样式 `style="height: 500px;"`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值