关于高德地图获取Key失败

首先使用开发工具是Android Studio,通过使用keytool命令获取SHA1,但是这样还是无法获取项目的准确签名,所以获取的的key是无法正常使用的。

可以通过一下代码将打印出来的项目包的签名重新获取即可。


  1. public static String getSHA1(Context context) {  
  2.         try {  
  3.             PackageInfo info = context.getPackageManager().getPackageInfo(  
  4.                     context.getPackageName(), PackageManager.GET_SIGNATURES);  
  5.   
  6.             byte[] cert = info.signatures[0].toByteArray();  
  7.   
  8.             MessageDigest md = MessageDigest.getInstance(”SHA1”);  
  9.             byte[] publicKey = md.digest(cert);  
  10.             StringBuffer hexString = new StringBuffer();  
  11.             for (int i = 0; i < publicKey.length; i++) {  
  12.                 String appendString = Integer.toHexString(0XFF & publicKey[i])  
  13.                         .toUpperCase(Locale.US);  
  14.                 if (appendString.length() == 1)  
  15.                     hexString.append(”0”);  
  16.                 hexString.append(appendString);  
  17.                 hexString.append(”:”);  
  18.             }  
  19.             return hexString.toString();  
  20.         } catch (PackageManager.NameNotFoundException e) {  
  21.             e.printStackTrace();  
  22.         } catch (NoSuchAlgorithmException e) {  
  23.             e.printStackTrace();  
  24.         }  
  25.         return null;  
  26.     }  
public static String getSHA1(Context context) {
        try {
            PackageInfo info = context.getPackageManager().getPackageInfo(
                    context.getPackageName(), PackageManager.GET_SIGNATURES);

            byte[] cert = info.signatures[0].toByteArray();

            MessageDigest md = MessageDigest.getInstance("SHA1");
            byte[] publicKey = md.digest(cert);
            StringBuffer hexString = new StringBuffer();
            for (int i = 0; i < publicKey.length; i++) {
                String appendString = Integer.toHexString(0XFF & publicKey[i])
                        .toUpperCase(Locale.US);
                if (appendString.length() == 1)
                    hexString.append("0");
                hexString.append(appendString);
                hexString.append(":");
            }
            return hexString.toString();
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return null;
    }


### Vue3 中集成高德地图 API 获取当前定位 在 Vue3 项目中集成高德地图获取用户的当前位置,可以通过以下方式实现。此过程涉及注册高德开发者账号、引入高德地图 JavaScript SDK 并使用 `AMap.Geolocation` 插件完成定位功能。 #### 1. 注册高德开发者账号并申请 Key 为了能够正常使用高德地图的服务,首先需要前往高德开放平台注册成为开发者,并创建应用以获得专属的 API 密钥[^1]。该密钥将在后续加载高德地图 JS 文件时被指定。 #### 2. 加载高德地图 JS 库 通过动态加载的方式,在 Vue 组件内部引入高德地图的 JavaScript SDK。以下是基于 Promise 的异步加载函数示例: ```javascript export default function MapLoader(key) { return new Promise((resolve, reject) => { if (window.AMap) { resolve(window.AMap); } else { const script = document.createElement('script'); script.type = 'text/javascript'; script.async = true; script.src = `https://webapi.amap.com/maps?v=1.4.15&key=${key}&callback=initAMap`; script.onerror = reject; document.head.appendChild(script); } window.initAMap = () => { resolve(window.AMap); }; }); } ``` 上述代码片段定义了一个名为 `MapLoader` 的工具函数用于按需加载高德地图库文件[^4]。 #### 3. 使用 AMap.Geolocation 进行定位 当成功初始化高德地图实例后,调用其内置插件 `AMap.Geolocation` 来请求设备的位置信息。下面是一个完整的 Vue3 组件案例演示如何操作这一流程: ```vue <template> <div id="mapContainer" style="width: 100%; height: 400px;"></div> </template> <script> import { onMounted } from "vue"; import MapLoader from "./utils/MapLoader"; export default { setup() { let mapInstance; async function initMapAndLocate() { try { // 替换为自己的高德地图 key const AMap = await MapLoader("your_amap_api_key_here"); mapInstance = new AMap.Map("mapContainer", { zoom: 12, }); const geolocationPlugin = new AMap.Geolocation({ enableHighAccuracy: true, // 是否启用高精度定位,默认:true timeout: 10000, // 超过10秒后停止定位,默认:无穷大 maximumAge: 0 // 定位结果缓存0毫秒,默认:0 }); mapInstance.addControl(geolocationPlugin); geolocationPlugin.getCurrentPosition(function(status, result){ if (status === 'complete') { console.log("用户位置:", result.position); // 输出纬经度对象 }else{ console.error("定位失败"); } }); } catch (error) { console.error(error.message || error); } } onMounted(() => { initMapAndLocate(); }); return {}; }, }; </script> ``` 以上代码展示了如何在一个简单的 Vue3 单文件组件里设置好地图容器并通过 `AMap.Geolocation` 执行精确定位[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值