Android中级篇之百度地图SDK v3.5.0-申请密钥详解[AndroidStudio下获取SHA1]

来源:互联网 发布:咖啡厅收银软件 编辑:程序博客网 时间:2024/05/17 01:29

申请密钥[比官方更详细]

在使用百度地图SDK为您提供的各种LBS能力之前,您需要获取百度地图移动版的开发密钥,该密钥与您的百度账户相关联。因此,您必须先有百度帐户,才能获得开发密钥。并且,该密钥与您创建的过程名称有关,具体流程请参考如下介绍。

Key的申请地址为:http://lbsyun.baidu.com/apiconsole/key

注意:

  1. 为了给用户提供更安全的服务,Android SDK自v2.1.3版本开始采用了全新的Key验证体系。因此,当您选择使用v2.1.3及之后版本的SDK时,需要到新的Key申请页面进行全新Key的申请;(新旧key不可通用)
  2. 新Key机制,每个Key仅且唯一对于1个应用验证有效,即对该Key配置环节中使用的包名匹配的应用有效。因此,多个应用【包括多个包名】需申请多个Key,或者对1个Key进行多次配置;
  3. 在新key机制下,若你需要在同一个工程中同时使用百度地图、定位、导航SDK可以共用同一个key;
  4. 如果您在Android SDK开发过程中使用了LBS云服务则需要为该服务单独申请一个for server类型的密钥;

  • 登录百度账号

    访问API控制台页面,若您未登录百度账号,将会进入百度账号登录页面,如下图:

    登录百度账号

  • 登陆API控制台

    登录会跳转到API控制台服务,具体如下图:

    登陆API控制台

  • 创建应用

    点击"创建应用",进入创建AK页面,输入应用名称,将应用类型改为:"Android SDK":

    创建应用
    选择项

  • 配置应用

    输入“安全码”。安全码的组成规则为:Android签名证书的sha1值+";"+packagename(即:数字签名+分号+包名),例如:BB:0D:AC:74:D3:21:E1:43:67:71:9B:62:91:AF:A1:66:6E:44:5D:75;com.baidumap.demo注意:中间的分号为英文状态下的分号!
  • Eclipse下Android签名证书的sha1值获取方式有两种:

    第一种方法:使用keytool第1步:运行进入控制台

    cmd
    进入路径

    第2步:定位到.android文件夹下,输入cd .android

    进入.android

    第3步:输入keytool -list -v -keystore debug.keystore,会得到三种指纹证书,选取SHA1类型的证书(密钥口令是android),例如:其中keytool为jdk自带工具;keystorefile为Android 签名证书文件

    输入密钥库口令
    SHA1值

    第二种方法:在adt 22中直接查看如果使用adt 22,可以在eclipse中直接查看:windows -> preferance -> android -> build。 如下图示:

    Eclipse

  • AndroidStudio下Android签名证书的SHA1值获取方式:

    解决Windows10用户AndroidStudio中Terminal无法输入问题,如下图所示:

    win10

    解决办法:1、打开cmd:

    打开cmd

    2、右键"点击"顶部标题栏,弹出菜单项并选择"属性":

    菜单项

    3、"属性"面板:

    属性

    4、勾选"使用旧版控制台(需要重新启动)":

    勾选

    5、点击"确定"并重启计算机,完成!

    完成

    Android Studio中获取SHA1证书指纹数据的方法:1、一般在C盘用户目录下查看自己的.android目录,没有找到的话搜索一下:

    Android目录

    2、复制路径:

    复制路径

    3、粘贴至AndroidStudio的Terminal中,并按照下图中顺序执行命令,最终获取到SHA1值:

    Terminal

  • 获取包名

    包名是Android应用程序本身在AndroidManifest.xml 中定义的名称,例如:

    包名

  • 成功创建KEY

    在输入安全码后,点击“确定”完成应用的配置工作,您将会得到一个创建的Key,请妥善保管您所申请的Key。到这您就可以使用新Key来完成您的开发工作了。

    成功创建KEY

0 0