业务需求:
客户端传入用户的经纬度,后端计算出该经纬度与指定经纬度之间的距离;
在面向百度之后,发现Redis在3.2之后推出GEO特性可以简单就解决这个需求;
为了验证其的可用性(误差不要太多),这里来写个demo,与在高德地图上获取的距离进行对比;
先获取某两个地点的距离及经纬度,这里获取的是北京西站和南站的,距离大概是5927米;
再获取到两个地点的经纬度,在代码中使用redis geo 进行计算,获取出距离与高德地图的进行对比

代码部分:
先引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
配置连接redis信息
spring:
redis:
host: localhost
port: 6379
测试代码:
@Autowired
private RedisTemplate redisTemplate;
@Test
public void getDistance(){
GeoOperations geoOperations = redisTemplate.opsForGeo();
//首先存入客户端上传的经纬度和指定地点的经纬度
Map<String,Object> map = new HashMap<>();
// 假如客户端的传的是北京西站的经纬度,指定地点是北京南站
map.put("BJXZ",new Point(116.321275,39.895096));
map.put("BJNZ",new Point(116.378438,39.864666));
// 将这些地址数据保存到redis中
geoOperations.geoAdd("GET_DISTANCE",map);
// 调用方法,计算北京西站与北京南站之间的距离;
double value = geoOperations.geoDist("GET_DISTANCE", "BJXZ", "BJNZ", RedisGeoCommands.DistanceUnit.METERS).getValue();
System.out.println("北京西站到南站的距离是"+value+"米");
System.out.println("与高德地图的误差是:"+(5927-value)+"米");
}
最终得出结果是:

915

被折叠的 条评论
为什么被折叠?



