百度android 定位返回161,重拾百度定位之踩坑篇(下)

接上文

实现BDLocationListener接口

/*****

* 定位结果回调,重写onReceiveLocation方法

*

*/

private BDLocationListener mListener = new BDLocationListener() {

@Override

publicvoid onReceiveLocation(BDLocation location) {

// TODO Auto-generated method stub

if (null!= location ) {

StringBuffer sb = new StringBuffer(256);

sb.append("time : ");

/**

* 时间也可以使用systemClock.elapsedRealtime()方法 获取的是自从开机以来,每次回调的时间;

* location.getTime() 是指服务端出本次结果的时间,如果位置不发生变化,则时间不变

*/

sb.append(location.getTime());

sb.append("\nlocType : ");// 定位类型

sb.append(location.getLocType());

sb.append("\nlocType description : ");// *****对应的定位类型说明*****

//sb.append(location.getLocTypeDescription());

sb.append("\nlatitude : ");// 纬度

sb.append(location.getLatitude());

sb.append("\nlontitude : ");// 经度

sb.append(location.getLongitude());

sb.append("\nradius : ");// 半径

sb.append(location.getRadius());

sb.append("\nCountryCode : ");// 国家码

sb.append(location.getCountryCode());

sb.append("\nCountry : ");// 国家名称

sb.append(location.getCountry());

sb.append("\ncitycode : ");// 城市编码

sb.append(location.getCityCode());

sb.append("\ncity : ");// 城市

sb.append(location.getCity());

sb.append("\nDistrict : ");// 区

sb.append(location.getDistrict());

sb.append("\nStreet : ");// 街道

sb.append(location.getStreet());

sb.append("\naddr : ");// 地址信息

sb.append(location.getAddrStr());

sb.append("\nUserIndoorState: ");// *****返回用户室内外判断结果*****

//sb.append(location.getUserIndoorState());

sb.append("\nDirection(not all devices have value): ");

sb.append(location.getDirection());// 方向

sb.append("\nlocationdescribe: ");

sb.append(location.getLocationDescribe());// 位置语义化信息

sb.append("\nPoi: ");// POI信息

if (location.getPoiList() != null&& !location.getPoiList().isEmpty()) {

for(inti = 0; i append(poi.getName() +";");

}

}

if (location.getLocType() == BDLocation.TypeGpsLocation) {// GPS定位结果

sb.append("\nspeed : ");

sb.append(location.getSpeed());// 速度 单位:km/h

sb.append("\nsatellite : ");

sb.append(location.getSatelliteNumber());// 卫星数目

sb.append("\nheight : ");

sb.append(location.getAltitude());// 海拔高度 单位:米

sb.append("\ngps status : ");

//sb.append(location.getGpsAccuracyStatus());// *****gps质量判断*****

sb.append("\ndescribe : ");

sb.append("gps定位成功");

} elseif (location.getLocType() == BDLocation.TypeNetWorkLocation) {// 网络定位结果

// 运营商信息

if (location.hasAltitude()) {// *****如果有海拔高度*****

sb.append("\nheight : ");

sb.append(location.getAltitude());// 单位:米

}

sb.append("\noperationers : ");// 运营商信息

sb.append(location.getOperators());

sb.append("\ndescribe : ");

sb.append("网络定位成功");

} elseif (location.getLocType() == BDLocation.TypeOffLineLocation) {// 离线定位结果

sb.append("\ndescribe : ");

sb.append("离线定位成功,离线定位结果也是有效的");

} elseif (location.getLocType() == BDLocation.TypeServerError) {

sb.append("\ndescribe : ");

sb.append("服务端网络定位失败,可以反馈IMEI号和大体定位时间到loc-bugs@baidu.com,会有人追查原因");

} elseif (location.getLocType() == BDLocation.TypeNetWorkException) {

sb.append("\ndescribe : ");

sb.append("网络不同导致定位失败,请检查网络是否通畅");

} elseif (location.getLocType() == BDLocation.TypeCriteriaException) {

sb.append("\ndescribe : ");

sb.append("无法获取有效定位依据导致定位失败,一般是由于手机的原因,处于飞行模式下一般会造成这种结果,可以试着重启手机");

}

tv_location.setText(sb+"\n定位结束");

locationService.stop();

}else{

tv_location.setText("\n定位失败");

}

}

};

通过上面的实现后,我们在想要定位的地方注册下回调,并调用start()方法即可以获取位置了,我对注册开始暂停做了下简单封装,具体代码参考LocationService。如果要写的项目里也要把回调接口封装,自定义一个接口回调返回定位后的详细位置信息。到这里即可成功定位了,下面就开始介绍下这个过程会出现的问题。

定位问题分析

在分析之前我们先看下百度定位返回的错误码,分析定位的问题也就是分析出现错误码的原因。

获取定位返回错误码::

publicintgetLocType ( )

返回值:

61 : GPS定位结果,GPS定位成功。

62 : 无法获取有效定位依据,定位失败,请检查运营商网络或者WiFi网络是否正常开启,尝试重新请求定位。

63 : 网络异常,没有成功向服务器发起请求,请确认当前测试手机网络是否通畅,尝试重新请求定位。

65 : 定位缓存的结果。

66 : 离线定位结果。通过requestOfflineLocaiton调用时对应的返回结果。

67 : 离线定位失败。通过requestOfflineLocaiton调用时对应的返回结果。

68 : 网络连接失败时,查找本地离线定位时对应的返回结果。

161: 网络定位结果,网络定位成功。

162: 请求串密文解析失败,一般是由于客户端SO文件加载失败造成,请严格参照开发指南或demo开发,放入对应SO文件。

167: 服务端定位失败,请您检查是否禁用获取位置信息权限,尝试重新请求定位。

502: AK参数错误,请按照说明文档重新申请AK。

505:AK不存在或者非法,请按照说明文档重新申请AK。

601: AK服务被开发者自己禁用,请按照说明文档重新申请AK。

602: keymcode不匹配,您的AK配置过程中安全码设置有问题,请确保:SHA1正确,“;”分号是英文状态;且包名是您当前运行应用的包名,请按照说明文档重新申请AK。

501~700:AK验证失败,请按照说明文档重新申请AK。

其实知道上面错误码代表的含义后,我们就很快速的定位问题出现地方。当然有些时候不如此,可能需要走一些弯路。

505错误

在我升级定位SDK版本后遇到得到就是这个问题,没有更改任何代码但是就是一直返回错误码是505.通过上面错误码表我们看到时AK不存在或者非法,但是依然很纠结,因为代码时点儿也没有改,只是替换了jar和.so文件为最新版就不能用了。定位一直返回505,最后在官网更新日志看到V7.0版本有一条记录 是优化、完善AK校验机制,充分保证开发者合法权益,保证开发者应用的安全性。具体怎么优化并没有说明。不过也能猜测应该是SHA1的值问题。我先将demo用的定位SDK用V6.2.2(项目中用的此版本),然后更改SHA1的值,不管怎么改依然能成功定位。但是更改为了V7.0版本发现SHA1的值并不能随便改,只能是运行程序用的key文件的SHA1的值,否则就出现505错误。至此问题解决。在V7.0之前版本虽说让填写SHA1的值,但是并没有什么有效作用,在V7.0版本开始加入了严格的校验。在这里提供一个软件可以校验APK的SHA1值,他提供了SHA1的和AK的校验功能。

eebc25076e35dbe0a9e72b9b625a5393.gif

如上图,这上面显示的SHA1的值应该和你开发版或者发布版中至少其中的一个相同。否则V7.0定位就不会成功。校验工具百度网盘下载链接,提取码:je4r。

162错误

162错误一般是.so文件加载失败引起的。在AndroidStudio中.so文件的位置和Eclipse中的是不一样的。默认情况下,AndroidStudio中.so文件放在main目录下,在该文件夹下创建jniLibs,然后将不同内核的.so文件放到该文件夹下就可以了。当然一些人延续了Eclipse位置,将.so文件放置在libs目录下,如果此时没有其他一些配置.so文件是不能加载的。此时再gradle文件加入下面代码即可

sourceSets {

main {

jniLibs.srcDirs = ['libs']

}

}

65bd39e022e32d66eeba478c59125175.png

其实最多出现的问题也就是这两种情况。正常情况下百度定位成功返回的是161也就是网络定位结果(如上图),但是有时候无网络会返回66机离线定位结果,离线定位是小区定位,需要手机手机中有SIM卡,否则不会返回66,你可以尝试下,把手机调到飞行模式,发现离线定位会失败。百度定位默认GPS定位是关闭的,如果想用GPS定位可以通过下面代码打开,

locationClientOption.setOpenGps(true);

BDLocationListener只回调一次

对于很多刚接触定位的人可能还会遇到一个问题就是,为何多次调用start()方法但是BDLocationListener回调只执行一次。每次只要程序刚启动时才能定位成功。之后再定位就没有反应了。如果你第一次遇到这个问题,确实很棘手,不管怎么改定位相关的代码,并不能解决问题。其实此时只需要在清单文件加入下面代码既可以解决BDLocationListener只会回调一次的问题

android:name="com.baidu.location.f"

android:enabled="true"

android:process=":remote">

好了,到此,本篇文章真的结束了,若文章有不足或者错误的地方,欢迎指正,以防止给其他读者错误引导

【编辑推荐】

【责任编辑:枯木 TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值