HTML5浏览器定位navigator.geolocation.getCurrentPosition无效了?

yyoinge 2014-07-04 09:57:44
这两天发现浏览器定位功能 navigator.geolocation.getCurrentPosition 总是超时,是接口本身的问题,还是我这边的网络问题(试过多台服务器,客户端,移动终端都不行)?

像这个网站:http://hgxdj.com/
还有这个:http://www.w3school.com.cn/tiy/t.asp?f=html5_geolocation_error
都无法定位
...全文
26296 17 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
17 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
基于安全考虑,不允许在非安全的HTTP协议下继续使用getCurrentPosition() 和 watchPosition()方法,且将来会取消对它们的支持。你需要把你的应用切换到安全的来源,比如HTTPS协议下。
qq_30134199 2016-08-02
  • 打赏
  • 举报
回复
getCurrentPosition() and watchPosition() are deprecated on insecure origins, and support will be removed in the future. You should consider switching your application to a secure origin, such as HTTPS. See https://goo.gl/rStTGz for more details. 报这个是怎么回事??
qq_32627285 2016-07-31
  • 打赏
  • 举报
回复
楼主解决了没,现在用5+里的navigator.geolocation写的,真机调试可以定位,打包之后安装到手机上就不定位了(并非网络问题),这种问题应该怎样解决。
业余草 2016-06-30
  • 打赏
  • 举报
回复
你看下百度的代码:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;}
#l-map{height:100%;width:78%;float:left;border-right:2px solid #bcbcbc;}
#r-result{height:100%;width:20%;float:left;}
</style>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.4"></script>
<title>浏览器定位</title>
</head>
<body>
<div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
var map = new BMap.Map("allmap");
var point = new BMap.Point(116.331398,39.897445);
map.centerAndZoom(point,12);

var geolocation = new BMap.Geolocation();
geolocation.getCurrentPosition(function(r){
    if(this.getStatus() == BMAP_STATUS_SUCCESS){
        var mk = new BMap.Marker(r.point);
        map.addOverlay(mk);
        map.panTo(r.point);
        alert('您的位置:'+r.point.lng+','+r.point.lat);
    }
    else {
        alert('failed'+this.getStatus());
    }       
});
</script>
//关于状态码 //BMAP_STATUS_SUCCESS 检索成功。对应数值“0”。 //BMAP_STATUS_CITY_LIST 城市列表。对应数值“1”。 //BMAP_STATUS_UNKNOWN_LOCATION 位置结果未知。对应数值“2”。 //BMAP_STATUS_UNKNOWN_ROUTE 导航结果未知。对应数值“3”。 //BMAP_STATUS_INVALID_KEY 非法密钥。对应数值“4”。 //BMAP_STATUS_INVALID_REQUEST 非法请求。对应数值“5”。 //BMAP_STATUS_PERMISSION_DENIED 没有权限。对应数值“6”。(自 1.1 新增) //BMAP_STATUS_SERVICE_UNAVAILABLE 服务不可用。对应数值“7”。(自 1.1 新增) //BMAP_STATUS_TIMEOUT 超时。对应数值“8”。(自 1.1 新增)
qq_29611437 2016-06-27
  • 打赏
  • 举报
回复
安卓机的话可能会跟GPS定位的模式有关,看看换个定位模式是否就可以了
业余草 2016-06-02
  • 打赏
  • 举报
回复
你的网络问题吧? 现在有没有找到问题的原因
suzhisheng0105 2016-05-31
  • 打赏
  • 举报
回复
楼主是怎么解决的,我现在也遇到此问题了
宗璞 2015-10-21
  • 打赏
  • 举报
回复
楼主怎么定位的,我也遇到这个问题了
lnwscn 2014-08-03
  • 打赏
  • 举报
回复
我也发现这个问题了,以前通过网页都能共享位置信息,现在不管用了, 电脑上的谷歌、火狐、欧朋浏览器都试过了,不行,安卓手机上的浏览器也不行 但是苹果浏览器可以定位,目前还不知道是什么原因
业余草 2014-07-04
  • 打赏
  • 举报
回复
我这里限制了,只能打开csdn网址
yyoinge 2014-07-04
  • 打赏
  • 举报
回复
引用 2 楼 yyoinge 的回复:
我上面贴得第一个网址里面就有代码
错了,是第二个
yyoinge 2014-07-04
  • 打赏
  • 举报
回复
我上面贴得第一个网址里面就有代码
业余草 2014-07-04
  • 打赏
  • 举报
回复
这个功能,能贴代码吗
yyoinge 2014-07-04
  • 打赏
  • 举报
回复
上面是调用百度地图的浏览器定位,会返回错误号 7BMAP_STATUS_SERVICE_UNAVAILABLE” 下面是html5的方法,会返回错误 “Location information is unavailable.
<!DOCTYPE html>
<html>
<body>
<p id="demo">点击这个按钮,获得您的坐标:</p>
<button onclick="getLocation()">试一下</button>
<script>
var x=document.getElementById("demo");
function getLocation()
  {
  if (navigator.geolocation)
    {
    navigator.geolocation.getCurrentPosition(showPosition,showError);
    }
  else{x.innerHTML="Geolocation is not supported by this browser.";}
  }
function showPosition(position)
  {
  x.innerHTML="Latitude: " + position.coords.latitude + 
  "<br />Longitude: " + position.coords.longitude;	
  }
function showError(error)
  {
  switch(error.code) 
    {
    case error.PERMISSION_DENIED:
      x.innerHTML="User denied the request for Geolocation."
      break;
    case error.POSITION_UNAVAILABLE:
      x.innerHTML="Location information is unavailable."
      break;
    case error.TIMEOUT:
      x.innerHTML="The request to get user location timed out."
      break;
    case error.UNKNOWN_ERROR:
      x.innerHTML="An unknown error occurred."
      break;
    }
  }
</script>
</body>
</html>
刚刚又试了某几台服务器,有的又可以了,有的还是不可以 我现在的疑问是: (1)什么样的网络环境,会导致浏览器定位出现这样的错误? (2)浏览器的定位为什么会不稳定? (3)在无法按GSP、WIFI、基站定位的情况下,不是至少应该可以按IP进行定位吗? (4)为什么在移动终端上,用上述两种方法定位,最终都是TimeOut超时,同样的移动终端上打开web百度地图,却可以精确的定位(误差大概在300米内)?
yyoinge 2014-07-04
  • 打赏
  • 举报
回复
var geolocation = new BMap.Geolocation();
		geolocation.getCurrentPosition(function(r){
		if(this.getStatus() == BMAP_STATUS_SUCCESS){
		var mk = new BMap.Marker(r.point);
		var myGeo = new BMap.Geocoder();
		myGeo.getLocation(new BMap.Point(r.point.lng,r.point.lat), function(rs){
         // console.log(MyApp.app.mapCenter);
          console.log(rs);
          var addComp = rs.addressComponents;
          alert(addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber);
      });		
		}
		else {
			alert('未知地址('+this.getStatus() + ')');
		}
	});

39,118

社区成员

发帖
与我相关
我的任务
社区描述
HTML5是构建Web内容的一种语言描述方式。HTML5是互联网的下一代标准,是构建以及呈现互联网内容的一种语言方式.被认为是互联网的核心技术之一。
社区管理员
  • HTML5社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧