Authentication Error errorcode: 230(APP scode校验失败)百度地图只显示网格线

本文详细介绍了在AndroidStudio中调用百度地图时遇到的问题及解决方法,包括SHA1签名一致性检查、百度API申请规则、避免重复应用ID导致的数据统计混淆等问题,并提供了解决地图无法显示仅显示网格线的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在此就Android Studio下调用百度地图时的细节做个总结,某个细节没有注意到,可能就是程序报错的原因。最初这一问题是从“230验证失败”开始的。之后的调试中遇到了更多别的bug。

执行Android Studio->build->Generate Signed APK,是用Studio自动打包签名,它会创建一个xxx.jks文件,通过命令keytool -v -list -keystore /Users/rose/downloads/xxx.jks 能够得到SHA1和MD5值。

我用这个SHA1和包名重现申请百度地图key,运行后一直报以下错误:
Authentication Error errorcode: 230 uid: -1 appid -1 msg: APP Scode码校验失败
实际上这种情况下,key就是无效的。根本就没有申请成功。我打开百度地图的API控制台,点击之前创建的那个应用,发现安全码栏显示的是”undefined;undefined”。

第一步:检查SHA1签名是否一致,若不一致,统一签名。
一个是你Android Studio里正在跑的工程,此处叫one.apk,一个你自动打包签名后的工程,此处叫2.apk.
1.apk的SHA1值通过安装工具查看,工具链接地址 http://pan.baidu.com/s/1ohYNG
2.apk的SHA1值在文章的开头已经获取到了,也就是通过生成的.jks 文件获取到的。

结果:如果不一致,那就统一签名。在工程的build.gradle中设置让debug和release版本指向同一个签名文件(生成的签名文件)。
在android{}中添加如下配置:

signingConfigs {
 release {
  storeFile file("/Users/rose/downloads/xxx.jks")
   storePassword "xxxxxxxx"
   keyAlias "xxxx"
   keyPassword "xxxxxxxx"
   }
}

buildTypes {
debug {
    signingConfig signingConfigs.release
   }
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
signingConfig signingConfigs.release
    }
}

签名一致之后,那么就不会存在生成的apk文件和环境里运行的apk文件运行效果不同的情况。不会出现环境中的能显示地图,而打包后的地图只显示网格的情况。要么都显示地图,要么都显示网格线。

第二步:解决地图无法显示,只能看到网格线的情况。确实是key出了问题。此时我拿着那个统一的SHA1再次去申请百度key,发现能够申请成功,不会出现undefined。但是我发现我在百度地图中创建的应用都是用的同一个包名和同一个SHA1值,只有应用的名称不同。站在数据统计的角度来讲,需要满足唯一性原则。也就是说百度地图做数据统计就是根据包名和SHA1值来进行识别的,如果用同一个包名和SHA1值创建多个不同的应用,会导致百度地图无法识别。
会报错:
{“status”:200,”message”:”APP不存在,AK有误请检查再重试”}
于是我删除了使用相同包名和签名创建的工程,只留下一个工程。再次运行程序,地图便能正常显示了。

此外使用百度地图还需要注意的是:在Android Studio环境下,要将.so库放在src/main/jniLibs 目录下,如果你直接放在libs下也会导致运行时报错。而如果使用Eclipse环境,则不需要创建jniLibs 目录,直接放在libs下就好。

图一

图二

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梅子专栏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值