ELK采集之nginx 之高德地图出城市IP分布图
高德地图经纬度查询定位怎么查
高德地图经纬度查询定位怎么查高德地图是一款广受欢迎的地图应用程序,提供了丰富的地图信息和定位服务。
如果您想查询特定位置的经纬度信息或查找一组经纬度对应的位置,高德地图提供了简便的方法来实现这些功能。
以下是使用高德地图进行经纬度查询和定位的步骤:1. 访问高德地图官方网站首先,在您的浏览器中打开高德地图官方网站。
您可以通过输入“高德地图官方网站”进行搜索,然后选择官方网站链接进行访问。
2. 进入地图界面一旦您进入高德地图官方网站,您将看到一个大的地图界面。
这是您开始进行经纬度查询和定位的起点。
3. 输入经纬度查询在地图界面的顶部工具栏上,您会看到一个搜索框。
在搜索框中,您可以输入经纬度信息来查询对应的位置。
输入的格式通常是“纬度, 经度”或“经度, 纬度”。
输入完毕后,按下“Enter”键或点击搜索按钮执行查询。
4. 查看查询结果高德地图将根据您的输入显示查询结果。
查询结果通常会在地图上以一个图标或标记的形式显示,并附带一些相关信息。
您可以点击标记或查看信息窗口来获取详细的位置信息。
5. 使用经纬度进行定位如果您已经拥有一组经纬度,您也可以使用它们在高德地图中进行定位。
只需将经纬度输入到搜索框中,并按下“Enter”键或点击搜索按钮,高德地图将定位到相应的位置。
6. 切换地图视图高德地图提供了多种地图视图,包括街道地图、卫星地图和混合地图。
您可以在地图界面的右上角找到一个按钮,用于切换地图视图。
点击该按钮,选择您想要查看的地图视图。
7. 获取更多位置信息除了经纬度之外,高德地图还提供了其他有用的位置信息。
您可以在查询结果或标记的信息窗口中找到这些信息。
它们可能包括地址、周边兴趣点、交通状况等。
通过查看这些信息,您可以更加全面地了解您所查询的位置。
8. 导航与路线规划如果您计划从当前位置到查询结果的位置,高德地图还提供导航和路线规划功能。
在信息窗口或查询结果的下方,您可能会看到一个导航或路线规划的按钮。
高精度差分在高德地图上的多点实时定位
高精度差分在高德地图上的多点实时定位作者:李庭威王峰汪进夏佩邱文添龙保任李学易来源:《电脑知识与技术》2017年第23期摘要:为了将高精度差分位置信息显示在高德地图上,通过搭建基于Python的服务器读取rtklib传来的位置信息,提取出经纬度并传给浏览器。
通过编写基于JavaScfipt的HTML文件,调用高德地图API,利用AJAX技术,在地图上实时更新测量点的位置。
实验结果实现了多点高精度差分定位的可视化。
关键词:rtklib;Python服务器;高德地图;JavaScript;实时定位1背景GPS(Global Positioning svstem)全球定位系统现在已经广泛应用于各行各业,可以提供覆盖全球的导航以及定位服务。
高精度的GPS测量必须要采用载波相位观测值。
RTK定位技术基于载波相位观测值,能够实时地提供测量点的三维定位坐标,而且可以精确到厘米级。
本项目用到的RTKLIB是日本东京海洋大学(Tokyo University of Marine Science and Technology)开发的开源程序包,供标准的GNSS全球导航系统使用。
高德地图是高德软件开发的一款免费在线导航产品,被广泛应用于智能手机和电脑上。
由于RTKLIB一次只能输出一个信号,所以本项目通过打开多个RT—KLIB窗口并设置不同的输出端口,传给基于Python 开发的多线程后台。
为了能在智能手机和电脑上都能实时显示定位点的位置,本项目开发了适用于多平台多终端的前端页面,并利用AJAX(Asynchronous Javascript And XML,异步的Javascript与XML技术),使得不用刷新页面也能在浏览器页面的高德地图中实时更新位置。
2高德地图多点实时定位的实现2.1搭建基于Python的服务器Python是一种面向对象、直译式的电脑程序语言。
它包含了一组功能完备的标准库,能够轻松完成很多常见的任务。
使用高德地图,利用搜索功能,获取地址详情、经纬度等信息
使⽤⾼德地图,利⽤搜索功能,获取地址详情、经纬度等信息效果展⽰需求:1、实现⾼德地图输⼊地址⾃动提⽰功能 ,根据筛选结果,默认显⽰第⼀个结果2、实现单击获取某个地点的经纬度和地址信息3、实现筛选地址标注点4、实现地图回显,再次打开地图定位到之前选中的地址展⽰详情5、封装地图组件可在项⽬中任意地⽅使⽤注意点:⾸先项⽬中需要引⽤⾼德地图,并且我同步引⽤了⾼德的PlaceSearch、AdvancedInfoWindow、Autocomplete这⼏个插件,⾼德提供同步引⽤和异步引⽤,异步引⽤的话,需要你⾃⼰去⾼德的⽂档看看<script src="https:///maps?v=1.4.15&key=换成你⾃⼰的key&plugin=AMap.PlaceSearch,AMap.AdvancedInfoWindow,AMap.Autocomplete"></script>⾸先发⼀份可直接打开看的vue⽂件<template><basic-container><el-button @click="openMap">打开地图选择</el-button><el-dialogtitle="地图选择":visible.sync="mapDialog"width="80%":close-on-click-modal="false":before-close="cancelMap"top="10vh"><div class="over-hide"><div id="myPageTop"><table><tr><td></td></tr><tr><td><el-inputplaceholder="请输⼊关键字进⾏查询"v-model="inputAddress"id="tipinput"@clear="inputHandle"@input="clickCancle"clearable></el-input></td></tr></table></div><div id="container" class="map"></div><br /><br /></div><span slot="footer" class="dialog-footer"><div class="t-a-l"><el-row class="infoAddressIpt"><el-col :span="2"><span>详细地址</span></el-col><el-col :span="22"><el-input v-model="saveAddress"></el-input></el-col></el-row><span class="spb">重要提醒:地址标准格式**市**区**路**号。
如何通过来访者IP定位google地图
如何通过来访者IP定位google地图随着国内各大品牌门户网站纷纷推出地图服务,如搜狗地图,百度地图、网易地图等,地图的应用变得越来越广泛,同时,很多网站管理员都将地图服务加入到自己的网站中,增添不少特色,当然,也给使用的人提供了很多方便。
最近本人一时兴起,利用google map api实现了通过来访者的IP定位google地图,同时提供对IP、域名归属地查询服务。
国内也有比较多提供地图服务的API,例如:51ditu,mapbar等,选择google map api的原因是其应用的广泛性,而且其最新版本提供了更多更好的功能,不过还处于测试阶段。
有兴趣的朋友可以上网搜索一下其相关资料。
下面我将如何实现IP定位功能和大家交流一下。
要想使用google map api,首先得获取Google地图API的密钥,获取网址为:/intl/zh-CN/apis/maps/signup.html,这一过程中,如果没有google帐户的话,还得注册用户。
获取到密钥之后接着下来利用它实现最简单的hello world网页,google提供了很多示例,大家可以访问这个网址:/intl/zh-CN/apis/maps/documentation/examples/in dex.html查看其示例,想看怎么实现,只要查看相应页面的源代码就可以了。
经过简单的一些复制,粘贴操作,马上就可以在你的网页上增加地图了,呵呵,是不是很简单呢!拥有自己的地图后我们马上实现通过IP定位google地图。
实现这个功能之前,我们得先准备些IP数据,假如你没有这些数据怎么办?没关系,我们可以享受免费大餐,国外著名的maxmind公司提供免费的IP地址库和相应的JAVA实现接口程序,大家可以通过链接/app/java进行下载,其免费数据准确率大概是70-80%,如果你想要更准确的数据,可以购买其收费数据,可以准确到90%以上,此外,我们还可以下载到国内著名的IP纯真数据库,准确率比maxmind的数据高多了,而且还是不断更新的,不过只限于国内的IP而言。
使用高德地图JS获取当前位置和经纬度
使⽤⾼德地图JS获取当前位置和经纬度先看效果,我做的是这样的,可以按地图位置来返回当前你点的位置(图⼀,⼆),也可以根据输⼊框的⾃动搜索(图三,四)HTML的代码:<div><input type="text" id="keyword" name="keyword" value="" onkeydown='keydown(event)'/><div id="result1" name="result1"></div><div>X:<input type="text" id="lngX" name="lngX" value=""/><br>Y:<input type="text" id="latY" name="latY" value=""/></div></div><div><a id='open'>地图定位</a></div>JS代码:<script type="text/javascript" src="/maps?v=1.3&key=您的Key值"></script><script>var windowsArr = [];document.getElementById('open').onclick = function() {if (document.getElementById('mapContainer').style.display == 'none') {document.getElementById('mapContainer').style.display = 'block';} else {document.getElementById('mapContainer').style.display = 'none';}}var mapObj = new AMap.Map("mapContainer", {resizeEnable: true,view: new AMap.View2D({resizeEnable: true,zoom:13//地图显⽰的缩放级别}),keyboardEnable:false});var marker = new AMap.Marker({map:mapObj,bubble:true})var clickEventListener=AMap.event.addListener(mapObj,'click',function(e){document.getElementById("lngX").value=e.lnglat.getLng();document.getElementById("latY").value=e.lnglat.getLat();AMap.plugin('AMap.Geocoder',function() {var geocoder = new AMap.Geocoder({city: "010"//城市,默认:“全国”});geocoder.getAddress(e.lnglat,function(status,result){if(status=='complete'){// marker.setPosition(e.lnglat);document.getElementById("keyword").value = result.regeocode.formattedAddressdocument.getElementById("result1").innerHTML = ''}else{document.getElementById("result1").innerHTML = '⽆法获取地址'}})})});document.getElementById("keyword").onkeyup = keydown;//输⼊提⽰function autoSearch() {var keywords = document.getElementById("keyword").value;var auto;//加载输⼊提⽰插件AMap.service(["AMap.Autocomplete"], function() {var autoOptions = {city: "" //城市,默认全国};auto = new AMap.Autocomplete(autoOptions);//查询成功时返回查询结果if ( keywords.length > 0) {auto.search(keywords, function(status, result){autocomplete_CallBack(result);});}else {document.getElementById("result1").style.display = "none";}});}//输出输⼊提⽰结果的回调函数function autocomplete_CallBack(data) {var resultStr = "";var tipArr = data.tips;if (tipArr&&tipArr.length>0) {for (var i = 0; i < tipArr.length; i++) {resultStr += "<div id='divid" + (i + 1) + "' onmouseover='openMarkerTipById(" + (i + 1)+ ",this)' onclick='selectResult(" + i + ")' onmouseout='onmouseout_MarkerStyle(" + (i + 1)+ ",this)' style=\"font-size: 13px;cursor:pointer;padding:5px 5px 5px 5px;\"" + "data=" + tipArr[i].adcode + ">" + tipArr[i].name + "<span style='color:#C1C1C1;'>"+ tipArr[i].district + "</span></div>"; }}else {resultStr = " π__π亲,⼈家找不到结果!<br />要不试试:<br />1.请确保所有字词拼写正确<br />2.尝试不同的关键字<br />3.尝试更宽泛的关键字";}document.getElementById("result1").curSelect = -1;document.getElementById("result1").tipArr = tipArr;document.getElementById("result1").innerHTML = resultStr;document.getElementById("result1").style.display = "block";}//输⼊提⽰框⿏标滑过时的样式function openMarkerTipById(pointid, thiss) { //根据id打开搜索结果点tipthiss.style.background = '#CAE1FF';}//输⼊提⽰框⿏标移出时的样式function onmouseout_MarkerStyle(pointid, thiss) { //⿏标移开后点样式恢复thiss.style.background = "";}//从输⼊提⽰框中选择关键字并查询function selectResult(index) {if(index<0){}if (erAgent.indexOf("MSIE") > 0) {document.getElementById("keyword").onpropertychange = null;document.getElementById("keyword").onfocus = focus_callback;}//截取输⼊提⽰的关键字部分var text = document.getElementById("divid" + (index + 1)).innerHTML.replace(/<[^>].*?>.*<\/[^>].*?>/g,"");var cityCode = document.getElementById("divid" + (index + 1)).getAttribute('data');document.getElementById("keyword").value = text;document.getElementById("result1").style.display = "none";//根据选择的输⼊提⽰关键字查询mapObj.plugin(["AMap.PlaceSearch"], function() {var msearch = new AMap.PlaceSearch(); //构造地点查询类AMap.event.addListener(msearch, "complete", placeSearch_CallBack); //查询成功时的回调函数msearch.setCity(cityCode);msearch.search(text); //关键字查询查询});}//定位选择输⼊提⽰关键字function focus_callback() {if (erAgent.indexOf("MSIE") > 0) {document.getElementById("keyword").onpropertychange = autoSearch;}}//输出关键字查询结果的回调函数function placeSearch_CallBack(data) {//清空地图上的InfoWindow和MarkerwindowsArr = [];marker = [];mapObj.clearMap();var resultStr1 = "";var poiArr = data.poiList.pois;var resultCount = poiArr.length;for (var i = 0; i < resultCount; i++) {resultStr1 += "<div id='divid" + (i + 1) + "' onmouseover='openMarkerTipById1(" + i + ",this)' onmouseout='onmouseout_MarkerStyle(" + (i + 1) + ",this)' style=\"font-size: 12px;cursor:pointer;padding:0px 0 4px 2px; border-bottom:1px s resultStr1 += TipContents(poiArr[i].type, poiArr[i].address, poiArr[i].tel) + "</td></tr></table></div>";addmarker(i, poiArr[i]);}mapObj.setFitView();}//⿏标滑过查询结果改变背景样式,根据id打开信息窗体function openMarkerTipById1(pointid, thiss) {thiss.style.background = '#CAE1FF';windowsArr[pointid].open(mapObj, marker[pointid]);}//添加查询结果的marker&infowindowfunction addmarker(i, d) {var lngX = d.location.getLng();var latY = d.location.getLat();var markerOption = {map:mapObj,icon:"/images/" + (i + 1) + ".png",position:new AMap.LngLat(lngX, latY)};var mar = new AMap.Marker(markerOption);marker.push(new AMap.LngLat(lngX, latY));var infoWindow = new Window({content:"<h3><font color=\"#00a6ac\"> " + (i + 1) + ". " + + "</font></h3>" + TipContents(d.type, d.address, d.tel),size:new AMap.Size(300, 0),autoMove:true,offset:new AMap.Pixel(0,-30)});windowsArr.push(infoWindow);var aa = function (e) {var nowPosition = mar.getPosition(),lng_str = nowPosition.lng,lat_str = t;infoWindow.open(mapObj, nowPosition);document.getElementById("lngX").value = lng_str;document.getElementById("latY").value = lat_str;};AMap.event.addListener(mar, "mouseover", aa);}//infowindow显⽰内容function TipContents(type, address, tel) { //窗体内容if (type == "" || type == "undefined" || type == null || type == " undefined" || typeof type == "undefined") {type = "暂⽆";}if (address == "" || address == "undefined" || address == null || address == " undefined" || typeof address == "undefined") {address = "暂⽆";}if (tel == "" || tel == "undefined" || tel == null || tel == " undefined" || typeof address == "tel") {tel = "暂⽆";}var str = " 地址:" + address + "<br /> 电话:" + tel + " <br /> 类型:" + type;return str;}function keydown(event){var key = (event||window.event).keyCode;var result = document.getElementById("result1")var cur = result.curSelect;if(key===40){if(cur + 1 < result.childNodes.length){if(result.childNodes[cur]){result.childNodes[cur].style.background='';}result.curSelect=cur+1;result.childNodes[cur+1].style.background='#CAE1FF';document.getElementById("keyword").value = result.tipArr[cur+1].name;}}else if(key===38){if(cur-1>=0){if(result.childNodes[cur]){result.childNodes[cur].style.background='';}result.curSelect=cur-1;result.childNodes[cur-1].style.background='#CAE1FF';document.getElementById("keyword").value = result.tipArr[cur-1].name;}}else if(key === 13){var res = document.getElementById("result1");if(res && res['curSelect'] !== -1){selectResult(document.getElementById("result1").curSelect);}}else{autoSearch();}}基本就是这样了。
ELK接收paloalto防火墙威胁日志并定位城市展示
ELK接收paloalto防⽕墙威胁⽇志并定位城市展⽰ELK接收paloalto防⽕墙威胁⽇志并定位城市展⽰⼀、准备环境:搭建好的ELK环境palo alto防⽕墙(企业⽤的)⼆、安装logstash并做好过滤将palo alto⽇志打到⼀台centos的rsyslog上并⽤logstash监听514端⼝这⾥⽤到了logstash的两个模块grok(分词)还有http(请求第三⽅api)百度地图的api⾃⾏到官⽹申请https:///apiconsole/key#/home配置如下:input{syslog{type => "syslog"port => 514}}filter {grok {match => ["message", "%{DATA:Domain}\,%{DATA:Receive-Time}\,%{DATA:Serial}\,%{DATA:Type}\,%{DATA:Threat-Type}\,%{DATA:Conf ig-Version}\,%{DATA:Generate-Time}\,%{IP:Source-address}\,%{IP:Destination-address}\,%{DATA:NAT-Source-IP}\,%{DATA:NAT-Destination -IP}\,%{DATA:Rule}\,%{DATA:Source-User}\,%{DATA:Destination-User}\,%{DATA:Application}\,%{DATA:Virtual-System}\,%{DATA:Source-Zone }\,%{DATA:Destination-Zone}\,%{DATA:Inbound-Interface}\,%{DATA:Outbound-Interface}\,%{DATA:Log-Action}\,%{DATA:Time-Logged}\,%{DAT A:Session-ID}\,%{DATA:Repeat-Count}\,%{DATA:Source-Port}\,%{DATA:Destination-Port}\,%{DATA:NAT-Source-Port}\,%{DATA:NAT-Destinatio n-Port}\,%{DATA:Flags}\,%{DATA:IP-Protocol}\,%{DATA:Action}\,%{DATA:URL}\,%{DATA:Threat-Content-Name}\,%{DATA:Category}\,%{DATA:Se verity}\,%{DATA:Direction}\,%{DATA:Sequence-Number}\,%{DATA:Action-Flags}\,%{DATA:Source-Country}\,%{DATA:Destination-Country}\,%{ DATA:cpadding}\,%{DATA:contenttype}\,%{DATA:pcap_id}\,%{DATA:filedigest}\,%{DATA:cloud}\,%{DATA:url_idx}\,%{DATA:user_agent}\,%{DA TA:filetype}\,%{DATA:xff}\,%{DATA:referer}\,%{DATA:sender}\,%{DATA:subject}\,%{DATA:recipient}\,%{DATA:reportid}\,%{DATA:dg_hier_l evel_1}\,%{DATA:dg_hier_level_2}\,%{DATA:dg_hier_level_3}\,%{DATA:dg_hier_level_4}\,%{DATA:Virtual-System-Name}\,%{DATA:Device-Nam e}\,%{DATA:file_url}"] }http {body_format => "json"follow_redirects => falseurl => "/location/ip?ak=我的AK&ip=%{Source-address}&coor=bd09ll"verb => "GET"headers => [ "Content-Type", "application/json" ]target_body => "address"}}output {elasticsearch {hosts => "xxxx:9200"user => "elastic"password => "passwd"index => "pa-threat-%{+yyyy.MM.dd}"}}三、运⾏这⾥建议⾃⼰选择合适的守护进程使⽤systemctl start logstash可能会有问题,推荐supervisor守护进程这边是我测试的使⽤nohup运⾏的,运⾏时⼀定要-f带上指定配置⽂件nohup /usr/share/logstash/bin/logstash -f /etc/logstash/conf.d/pa.conf >> /root/logstash-logs/logs 2>&1 &四、结果⽇志⾥就有请求的地址信息了,后⾯就可以⾃⼰做图表了五、注意点更改logstash配置后fields会出现未知fields 根据下⾯步骤更新fields即可!。
高德地图api之location定位
⾼德地图api之location定位关于定位,分为GPS定位和⽹络定位。
本⽂将详细描述的浏览器定位,属于⽹络定位。
这是⼀种通过使⽤⾼德JS-API来实现位置定位、城市定位的⽅法,包含了IP定位,检索等多种⽹络定位⽅式。
如果您的⼿机⽀持GPS功能,能够⾃动获取GPS信息,定位将更加准确。
浏览器定位浏览器定位插件,封装了标准的HTML5定位,并含纠正模块,同时该定位⽅式仅适⽤于⽀持HTML5的浏览器上,如Internet Explorer 9、Firefox、Chrome、Safari 以及 Opera等。
代码如下:/*** Created by ly-wangweiq on 2015/7/29.* * support mobile*///⽤户位置定位使⽤geolocation定位var mMap=function(){function rad(d){return d*Math.PI/180.0;}this.map={},this.geolocation={},this.k=0,//加载地图,调⽤浏览器定位服务this.initMap=function(mapContainer,completFunc){if(typeof(AMap)=="object"){this.map = new AMap.Map(mapContainer, {resizeEnable: true});this.map.plugin('AMap.Geolocation', function () {this.geolocation = new AMap.Geolocation({enableHighAccuracy: true,//是否使⽤⾼精度定位,默认:truetimeout: 10000, //超过10秒后停⽌定位,默认:⽆穷⼤maximumAge: 0, //定位结果缓存0毫秒,默认:0convert: true, //⾃动偏移坐标,偏移后的坐标为⾼德坐标,默认:trueshowButton: true, //显⽰定位按钮,默认:truebuttonPosition: 'LB', //定位按钮停靠位置,默认:'LB',左下⾓buttonOffset: new AMap.Pixel(10, 20),//定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)showMarker: true, //定位成功后在定位到的位置显⽰点标记,默认:trueshowCircle: true, //定位成功后⽤圆圈表⽰定位精度范围,默认:truepanToLocation: true, //定位成功后将定位到的位置作为地图中⼼点,默认:truezoomToAccuracy:true //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false});this.map.addControl(this.geolocation);AMap.event.addListener(this.geolocation, 'complete', onComplete);//返回定位信息AMap.event.addListener(this.geolocation, 'error', onError); //返回定位出错信息});function onComplete(data){console.log(completFunc)console.log(data)if(completFunc){completFunc(data);}}function onError(){var str = '定位失败,';str += '错误信息:'switch() {case 'PERMISSION_DENIED':str += '浏览器阻⽌了定位操作';break;case 'POSITION_UNAVAILBLE':str += '⽆法获得当前位置';break;case 'TIMEOUT':str += '定位超时';break;default:str += '未知错误';break;}alert(str)}}},this.getCurrentPosition=function(callback){if(typeof(this.geolocation.getCurrentPosition)!='undefined'){this.geolocation.getCurrentPosition();}else{setTimeout(function(){//将获得的经纬度信息,放⼊sessionStorgethis.getSessionLocation(callback)},200)}},this.distance = function(obj1,obj2){//return:mvar lng=new AMap.LngLat(obj1.lng, t);var lag=new AMap.LngLat(obj2.lng, t);var ss=lng.distance(lag);return ss;},this.getSessionLocation=function(callback){if(sessionStorage.getItem('location')){callback();}else{this.initMap('',function(data){sessionStorage.setItem("location",JSON.stringify(data))callback();});this.getCurrentPosition(callback);}},/**两点之间的距离*(t1)地址⼀的经纬度*(t2)地址⼀的经纬度*单位⽶*/this.serverDistance = function(obj1,obj2){//return:mvar radLat1 = rad(t);var radLat2 = rad(t);var a = radLat1 - radLat2;var b = rad(obj1.lng)- rad(obj2.lng);var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) + Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));s = s *6378137;s = Math.round(s * 10000)/10000 ;return s;}return this;}();这⾥将定位获取的信息存⼊sessionStorge中,这样只需要⾸次访问时,需要定位,之后都可以从sessionStorge中得到,⼤⼤提⾼了速度。
高德地图数据采集方法
高德地图数据采集方法本文介绍使用八爪鱼采集高德地图数据(以美食地址为例)的方法。
采集网站:/采集的内容包括:店铺名,分类,地址,联系号码使用功能点:●创建循环翻页●分页列表信息采集●Ajax设置步骤1:创建高德地图数据采集任务1)进入主界面,选择“自定义采集2)将要采集的网站URL复制粘贴到输入框中,点击“保存网址”步骤2:文本输入1)鼠标移动到地址选择框,在右面的提示框中选择“点击该元素”然后鼠标选中输入框,在提示框中选择“输入文字”3)在弹出的输入框中输入要采集的城市,这里以新乡为例,然后点击确定。
鼠标点击新乡,并在输入框中选择“点击该元素”步骤3:创建翻页循环1)移动鼠标,在右面拖入一个循环框,如下图所示鼠标点击输入框,在右面提示框中选择“输入文字”,然后选择确定把输入文字的步骤拖入规则流程,在高级选项中选择执行前等待“2秒”,选择文本列表,并在列表中输入需要采集的品类,这里以菜系为例,如下图可输入“火锅”等。
鼠标选中输入文本步骤,高级选项中勾选使用当前循环里的文本来填充输入框2)鼠标点中搜索框,接着选择“循环点击每个元素”。
3)进入火锅店列表页后,鼠标移动到最后并选中翻页按钮,在右面的提示框中选择”循环点击的单个元素“3)之后选中火锅店的第一条链接,系统自动识别出其他的元素后,在右面的提示框中选择“选中全部”,以创建循环翻页。
再选择“循环点击单个元素”步骤4:高德地图数据提取详细信息1)进入列表详情页以后,选中店名,然后在右面的提示框中选择“采集该元素文本”,同样操作,可以把地址、分类等信息采集下来。
2)然后鼠标点中字段旁边的编辑标识,可以对提取字段的自定义命名,点中旁边的删除标识可以删除不需要的字段。
鼠标选中返回,然后选择“点击该元素”步骤5:Ajax设置由于此网页涉及Ajax技术,我们需要进行一些高级选项的设置。
选中“点击元素”步骤,打开“高级选项”,勾选“Ajax加载数据”,设置时间为“2秒”。
高德地图经纬度查询地点
高德地图经纬度查询地点在现代社会中,随着科技的不断进步和人们生活水平的提高,地图导航已经成为我们日常生活中不可或缺的一部分。
高德地图作为国内领先的地图导航服务提供商,不仅提供了丰富的地图数据和导航功能,还为用户提供了经纬度查询功能,方便用户快速地获取想要查询地点的经度和纬度。
如何进行高德地图经纬度查询地点要进行高德地图经纬度查询地点,首先需要打开高德地图网站或者在手机上打开高德地图应用。
接下来,按照以下步骤进行查询:1.打开高德地图网站或应用。
2.在搜索框中输入你想要查询的地点或地址。
3.高德地图将自动搜索并显示与你输入信息相关的地点。
4.选择你要查询的地点或地址,并点击进入详情页面。
5.在详情页面中,你可以看到该地点的详细信息,包括经度和纬度。
高德地图经纬度查询地点的作用高德地图经纬度查询地点功能的作用主要体现在以下几个方面:1. 地址精确定位通过高德地图经纬度查询地点,用户可以获得目标地点的精确经度和纬度信息。
这个信息对于需要精确定位的场景非常有用,比如外卖送餐、快递派送、约会会面等。
只要将查询到的经纬度信息提供给相应的服务提供商,他们就可以准确定位到用户所指定的地点,确保服务的准确性。
2. 方便交流和定位共享在日常生活中,人们经常需要与他人分享特定地点的位置信息,比如告诉朋友们自己的家庭住址、约定见面地点等。
而通过高德地图经纬度查询地点功能,用户可以方便地获取这些地点的经纬度信息,并通过各种通信工具将这些信息分享给他人,以便于大家进行交流和定位共享。
3. 旅游出行导航对于喜爱旅游出行的人们而言,高德地图经纬度查询地点功能也是非常有用的。
通过查询目的地的经纬度,用户可以用自己喜欢的导航软件或设备直接导航到目的地,避免迷路或浪费时间。
此外,许多旅游攻略软件和平台也使用经纬度信息来标记和推荐各种旅游景点,方便游客找到自己感兴趣的地点。
结语高德地图经纬度查询地点功能的便利性和实用性不言而喻,它为我们的日常生活和工作提供了很多便利。
vue+高德地图实现地图搜索及点击定位操作
vue+⾼德地图实现地图搜索及点击定位操作⾸先需要在index.html中引⼊⾼德地图的js链接,key需要换成你⾃⼰的key最近有个需求是实现⼀个使⽤地图搜索定位的功能,在⽹上参考了下其他的⽂章,感觉不是很完善,⾃⼰整理了⼀下,可以实现点击定位,搜索列表定位等功能,可能有些地⽅是多余的,需要的⾃⼰看着改下<script type="text/javascript" src="https:///maps?v=1.4.14&key=你的key"></script>效果图如下下边就是实现过程html部分<template><div id="wrap"><div id="searchWrap"><div class="searchWrap"><input type="text" v-model="address" @input="search"><button @click="search">搜索</button></div><div id="result" class="amap_lib_placeSearch" v-show="hide"><div class="amap_lib_placeSearch_list amap-pl-pc" v-for="(item,index) in poiArr"@click="openMarkerTipById(index,$event)"@mouseout="onmouseout_MarkerStyle(index+1,$event)":key="index"><div class="poibox" style="border-bottom: 1px solid #eaeaea"><div class="amap_lib_placeSearch_poi poibox-icon" :class="index==selectedIndex?'selected':''">{{index+1}}</div><div class="poi-img" v-if="item.url" :style="'background-image:url('+item.url+'?operate=merge&w=90&h=56&position=5)'"></div><h3 class="poi-title" ><span class="poi-name">{{}}</span></h3><div class="poi-info"><p class="poi-addr">地址:{{item.address}}</p><p class="poi-tel">电话:{{item.tel}}</p></div><div class="clear"></div></div></div></div></div><div id="iCenter"></div><button class="btn" @click="fetAddressName">获取当前位置和名字</button></div></template>js部分<script>export default {props:['newAddress','dataObj'],// ⽗组件传过来的地址和地址经纬度信息,data() {return {address:this.newAddress ? this.newAddress : '郑州',//保存地址的汉字名字map1: '',map:'',//保存地址的经纬度poiArr: [],//左边搜索出来的数组windowsArr: [],//信息窗⼝的数组marker: [],mapObj: "",//地图对象selectedIndex: -1,hide: false,clickType: 1,location:{P:t,Q:this.dataObj.lng,}};},mounted() {console.log(333,this.dataObj,this.location)this.mapInit()this.placeSearch(this.address)},methods: {showToast(address){this.placeSearch(address.address)console.log(444,address)this.location.P =tthis.location.Q =address.lngthis.address = address.addresslet that = this;new Window({content:"<h3>" + '当前选中地址' + "</h3>" + that.address,size: new AMap.Size(300, 0),autoMove: true,offset: new AMap.Pixel(-4, -10)}).open(that.mapObj,that.location)},cancelSave(){eventBus.$emit('cancelSave')},saveAddress(){let addressName,location;if(this.clickType==1){let address = this.poiArr[this.selectedIndex]addressName = +address.address;location = address.locationconsole.log(+address.address,address.location)}else if(this.clickType==2){console.log(this.address,this.map)addressName = this.address;location = this.map;}else if(this.clickType==3){console.log(this.address,this.map1)addressName = this.address;location = this.map1;}eventBus.$emit('saveAddress',[addressName,location])},// 经纬度转化为详细地址getAddress(){let that = this;AMap.plugin('AMap.Geocoder',function(){let geocoder = new AMap.Geocoder({radius: 100,extensions: "all"});geocoder.getAddress([that.map1.lng,t], function(status, result) {if (status === 'complete' && === 'OK') {let address = result.regeocode.formattedAddress;console.log(result.regeocode);that.address = result.regeocode.formattedAddress;// that.placeSearch(that.address)}});})},// 地图点击事件testevent(){let that = this;this.clickType = 3// var map=new AMap.Map('iCenter');//重新new出⼀个对象,传⼊参数是div的idAMap.event.addListener(this.mapObj,'click',function (e) { //添加点击事件,传⼊对象名,事件名,回调函数 that.map1 = e.lnglat;that.getAddress();setTimeout(()=>{new Window({content:"<h3>" + '当前选中地址' + "</h3>" + that.address,size: new AMap.Size(300, 0),autoMove: true,offset: new AMap.Pixel(-4, -10)}).open(that.mapObj,e.lnglat)},100)})},//创建⼀个mapmapInit() {this.mapObj = new AMap.Map("iCenter", {resizeEnable: true,zoom: 10,})this.testevent();},//根据名字地址去搜索结果placeSearch(name) {let that = this;this.hide = truevar MSearch;this.mapObj.plugin(["AMap.PlaceSearch", "AMap.ToolBar", "AMap.Scale"],() => {this.mapObj.addControl(new AMap.ToolBar())this.mapObj.addControl(new AMap.Scale())MSearch = new AMap.PlaceSearch({//构造地点查询类city: that.address //城市});AMap.event.addListener(MSearch,"complete",this.keywordSearch_CallBack) //返回地点查询结果MSearch.search(name); //关键字查询});},//结果的回调keywordSearch_CallBack(data) {console.log(111,data)var poiArr = data.poiList.poisvar resultCount = poiArr.lengththis.poiArr = poiArr; //左边要渲染的数据for (var i = 0; i < resultCount; i++) {this.addmarker(i, poiArr[i])console.log(poiArr[i])this.poiArr[i].url = this.poiArr[i].photos? this.poiArr[i].photos[0]? this.poiArr[i].photos[0].url: "": ""}this.mapObj.setFitView()},//添加marker&infowindowaddmarker(i, d) {var lngX = d.location.getLng();var latY = d.location.getLat();console.log(lngX,latY)var markerOption = {map: this.mapObj,position: new AMap.LngLat(lngX, latY)};var mar = new AMap.Marker(markerOption);this.marker.push(new AMap.LngLat(lngX, latY));var infoWindow = new Window({content: "<h3>" +'当前选中位置:'+ + "</h3>" + this.TipContents(, d.address), size: new AMap.Size(300, 0),autoMove: true,offset: new AMap.Pixel(0, -30)});console.log()this.windowsArr.push(infoWindow);var _this = this;var aa = (e) => {this.clickType = 2var obj = mar.getPosition();this.map = obj //这⾥保存的地址经纬度this.address = + d.address //这⾥保存的是地址名字infoWindow.open(_this.mapObj, obj);}AMap.event.addListener(mar, "click", aa)},TipContents(name, address) {//窗体内容if (name == "" ||name == "undefined" ||name == null ||name == " undefined" ||typeof name == "undefined") {type = "暂⽆";}if (address == "" ||address == "undefined" ||address == null ||address == " undefined" ||typeof address == "undefined") {address = "暂⽆";}var str = `地址:${address}`return str},openMarkerTipById(pointid, event) {//根据id 打开搜索结果点tipthis.clickType = 1event.currentTarget.style.background = "#CAE1FF";this.selectedIndex = pointid// this.map = this.marker[pointid]this.map1 = this.poiArr[pointid].locationconsole.log(222,this.mapObj, this.marker[pointid])console.log(this.marker[pointid],this.poiArr[pointid])this.address = this.poiArr[pointid].address + this.poiArr[pointid].namethis.windowsArr[pointid].open(this.mapObj, this.marker[pointid])},onmouseout_MarkerStyle(pointid, event) {//⿏标移开后点样式恢复event.currentTarget.style.background = ""},search() {this.windowsArr = []this.marker = []this.mapObj=''this.mapInit()this.placeSearch(this.address)}},};</script>css部分<style lang="scss">#wrap{width:100%;display: flex;#iCenter {height: 600px;position: relative;display: flex;flex: 1;}#searchWrap{width:300px;position: relative;height:600px;.searchWrap{position: absolute;width:300px;z-index: 9;display: flex;align-items: center;input{width:260px;height:24px;}button{width:36px;height:28px;}}#result {width: 300px;position: absolute;top:30px;height: 570px;z-index: 8;overflow-y: scroll;border-right: 1px solid #ccc;}}.amap_lib_placeSearch {height: 100%;overflow-y: scroll;.poibox {border-bottom: 1px solid #eaeaea;cursor: pointer;padding: 5px 0 5px 10px;position: relative;min-height: 35px;.selected {background-image: url(https:///theme/v1.3/markers/n/mark_r.png) !important;}&:hover {background: #f6f6f6;}.poi-img {float: right;margin: 3px 8px 0;width: 90px;height: 56px;overflow: hidden;}.poi-title {margin-left: 25px;font-size: 13px;overflow: hidden;}.poi-info {word-break: break-all;margin: 0 0 0 25px;overflow: hidden;p {color: #999;font-family: Tahoma;line-height: 20px;font-size: 12px;}}.poibox-icon {margin-left: 7px;margin-top: 4px;}.amap_lib_placeSearch_poi {background: url(https:///theme/v1.3/markers/n/mark_b.png)no-repeat;height: 31px;width: 19px;cursor: pointer;left: -1px;text-align: center;color: #fff;font: 12px arial, simsun, sans-serif;padding-top: 3px;position: absolute;}}}.btn{position: fixed;bottom:20px;left:50%;padding:10px;}}</style>补充知识:vue-amap ⾼德地图定位点击获取经纬度和具体地址的使⽤官⽅⽂档地址:经纬度获取只要通过点击事件就可以通过e.lnglat来获取,然后就是插件Geocoder使⽤了。
vue项目中使用高德地图(根据坐标定位点)
vue项⽬中使⽤⾼德地图(根据坐标定位点)前⾔项⽬中需要根据坐标定位,将⾃⼰的实现过程写下来,废话不多说,上代码正⽂<script>var map,marker;export default {data(){return{arriveCoor:[108.947025,34.2613255],//坐标点arrive:"",//位置信息}},mounted() {mapDraw(this.arriveCoor),mapCoor(this.arriveCoor)},methods:{mapDraw(arriveCoor){map = new AMap.Map('map-location', { //map-location是嵌地图div的idresizeEnable: true, //是否监控地图容器尺⼨变化zoom:16, //初始化地图层级center: arriveCoor //初始化地图中⼼点});// 定位点this.addMarker(arriveCoor);},// 实例化点标记addMarker(arriveCoor) {var _this = this;marker = new AMap.Marker({icon: "", //图⽚ipimageSize: "20px",position: arriveCoor,offset: new AMap.Pixel(-13, -30),// 设置是否可以拖拽draggable: true,cursor: 'move',// 设置拖拽效果raiseOnDrag: true});marker.setMap(map);}, // 查询坐标 mapCoor(lnglatXY){ var _this = this; AMap.service('AMap.Geocoder',function() {//回调函数 var geocoder = new AMap.Geocoder({}); geocoder.getAddress(lnglatXY, function (status, result) { if (status === 'complete' && === 'OK') { //获得了有效的地址信息: _this.arrive = result.regeocode.formattedAddress; else { _this.arrive = "暂⽆位置"; } }); }) },}</script>总结以上就是本⽂的全部内容了,希望对⼤家有所帮助,若是有疑问或是对⽂中内容有争议,请评论留⾔!。
ELK采集之nginx 之高德地图出城市IP分布图
最后看一下通常大家都会设置的 nginx 配置:默认 patterns 在一下目录 vendor/bundle/jruby/1.9/gems/logstash-patterns-core-4.0.2/patterns
1、 默认看一下 nginx 的日志格式: log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"';
convert => [ "[geoip][coordinates]", "float"] }
} output {
elasticsearch { action => "index" hosts =>"192.168.10.100:9200" index => "logstash-nginx-%{+yyyy.MM.dd}" } }
####测试返回的结果: {
"request" => "/favicon.ico", "agent" => "\"Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKi
t/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36\"", "geoip" => {
如何通过IP地址判断用户的地理位置的方式
如何通过IP地址判断用户的地理位置的方式IP地址,即互联网协议地址,是用于标识互联网上设备的数字地址。
通过IP地址,我们可以定位用户的地理位置,从而为用户提供个性化的服务。
本文将介绍几种常用的方式,以及它们的优缺点。
一、基于地理数据库的IP地址查询通过使用地理数据库,我们可以将IP地址映射到具体的地理位置。
这种方式的实现主要分为两步:首先是获取用户的IP地址,可以通过服务器端记录用户访问时的IP地址来实现;接着,利用地理数据库查询IP地址所对应的地理位置信息,如国家、城市、经纬度等。
该方式具有以下优点:1. 精确度较高:地理数据库通常会提供详细的地理信息,能够准确地确定用户的地理位置。
2. 快速响应:查询过程较快,能够在短时间内返回结果。
然而,基于地理数据库的IP地址查询也存在一些缺点:1. 数据库更新不及时:由于地理位置的变动较频繁,地理数据库可能无法及时更新,导致查询结果不准确。
2. 数据库成本较高:获取和维护地理数据库需要一定的成本,对于个人用户而言可能不太容易实现。
二、基于第三方地理定位服务的IP地址查询除了使用自建的地理数据库,我们还可以利用一些第三方的地理定位服务来获得IP地址对应的地理位置信息。
这些服务通常提供开放的API接口,通过向接口发送请求,即可获取所需的地理位置数据。
这种方式具有以下优点:1. 方便快捷:第三方地理定位服务通常提供简洁易用的API接口,操作简单,使用方便。
2. 实时性好:第三方地理定位服务会定期更新地理位置数据,保障查询结果的准确性。
然而,使用第三方地理定位服务也存在一些限制:1. 部分服务收费:有些服务对使用次数有限制,需要付费才能获得更多的查询次数。
2. 隐私问题:由于查询过程需要向第三方服务提供商发送用户的IP地址,存在隐私泄露的风险。
在使用时需要注意相关法律法规的规定,确保用户隐私的安全。
三、基于GPS定位的IP地址查询GPS(Global Positioning System),即全球定位系统,是一种利用卫星定位的技术,可以获取设备的精确地理位置信息。
高德经纬度坐标定位查询
高德经纬度坐标定位查询
在现代社会中,随着全球定位系统(GPS)的普及和应用,越来越多的应用程序和服务开始依赖于精确定位信息。
高德地图提供了强大的坐标定位查询服务,可以根据经纬度坐标来获取具体的位置信息。
什么是高德经纬度坐标?
高德经纬度坐标是一种标识地球上某个具体位置的数学系统。
经纬度坐标由一个纬度值和一个经度值组成,分别表示一个点在北纬/南纬和东经/西经方向上的位置。
纬度值范围从-90°到90°,经度值范围从-180°到180°。
例如,北京市的经纬度坐标为39.9042°N,116.4074°E。
高德地图坐标查询服务
高德地图提供了方便的经纬度坐标查询服务,可以根据经纬度坐标来获取具体的位置信息。
下面是如何使用高德地图坐标查询服务的步骤:
1. 获取高德开发者密钥
在使用高德地图的任何服务之前,您需要先获取一个高德开发者密钥。
您可以在高德开放平台的网站上注册一个开发者账号并创建一个应用,然后在应用详情页面获取到开发者密钥。
2. 构建请求URL
使用高德地图坐标查询服务,您需要构建一个HTTP请求URL。
URL包含以下参数:
•key:您的高德开发者密钥
•location:待查询的经纬度坐标,格式为。
高德AMAP行政区划边界及经纬度获取(2021年整理)
(完整)高德AMAP行政区划边界及经纬度获取(word版可编辑修改) 编辑整理:尊敬的读者朋友们:这里是精品文档编辑中心,本文档内容是由我和我的同事精心编辑整理后发布的,发布之前我们对文中内容进行仔细校对,但是难免会有疏漏的地方,但是任然希望((完整)高德AMAP行政区划边界及经纬度获取(word版可编辑修改))的内容能够给您的工作和学习带来便利。
同时也真诚的希望收到您的建议和反馈,这将是我们进步的源泉,前进的动力。
本文可编辑可修改,如果觉得对您有帮助请收藏以便随时查阅,最后祝您生活愉快业绩进步,以下为(完整)高德AMAP行政区划边界及经纬度获取(word版可编辑修改)的全部内容。
〈!DOCTYPE HTML><html〉<head><meta http—equiv=”Content-Type" content=”text/html; charset=utf-8”〉〈title>行政区划边界</title〉〈link rel=”stylesheet" type=”text/css"href="http://developer.amap。
com/Public/css/demo.Default。
css” />〈script language="javascript”src=”http://webapi.amap。
com/maps?v=1.3&key=7de8697669288fc848e12a08f58d995e"〉〈/script>〈script language="javascript"〉var mapObj,district;/**初始化地图对象,加载地图*/function mapInit(){mapObj = new AMap.Map(”iCenter",{view: new AMap。
高德gps坐标查询
高德GPS坐标查询简介高德地图是中国领先的数字地图内容、导航和位置服务解决方案提供商。
作为一家专业的地图服务提供商,高德地图提供了丰富的地理信息数据和强大的地图应用程序,涵盖了道路导航、实时交通、公共交通导航、地理搜索等功能。
其中,高德GPS坐标查询是其中的一项重要功能,能够根据经纬度坐标获取对应的具体位置信息。
功能高德GPS坐标查询功能允许用户根据给定的经纬度坐标,查询对应的位置信息。
这对于开发地理信息应用程序和服务十分有用。
通过高德GPS坐标查询,用户可以获取到准确的位置信息,包括国家、省份、城市、区县以及具体的街道和建筑物等。
这一功能为用户提供了便利,能够满足不同场景下的需求。
使用方法用户可以通过以下方法使用高德GPS坐标查询功能:1.准备坐标:在使用高德GPS坐标查询之前,首先需要获得要查询的经纬度坐标。
经度是指地球表面上某一点与本初子午线之间的角度,单位为度;纬度是指某一点与赤道之间的角度,单位为度。
用户可以通过各种地图服务或相关工具获取到想要查询的经纬度坐标。
2.发送请求:根据准备好的坐标,用户可以通过HTTP GET请求向高德地图的接口发送查询请求。
请求的URL中需要附带参数,包括key(用户的身份标识)和location(要查询的经纬度坐标)等。
用户还可以根据需要设置一些其他的可选参数,如输出结果的格式等。
3.解析结果:用户收到高德地图接口返回的查询结果后,可以对结果进行解析和处理。
结果以JSON格式返回,可以从中提取出具体的位置信息。
例如,用户可以获取到查询位置所在的国家、省份、城市、区县以及街道等信息。
示例以下是一个示例,展示了如何使用高德GPS坐标查询功能:```python import requestsdef query_location(longitude, latitude): url =。
高德导航(autonavi)地图数据包中的城市列表和编号
高德导航(autonavi)地图数据包中的城市列表和编号下面是高德导航地图数据包中各城市的名称及编号,之前找了好久没找到,应该也有很多人需要,放出来跟大家分享一下。
" 淮北市" HBS3406" 合肥市" HFS3401" 淮南市" HNS3404" 黄山市" HSS3410" 六安市" LAS3415" 马鞍山市" MASS3405" 宿州市" SZS3413" 铜陵市" TLS3407" 芜湖市" WHS3402" 宣城市" XCS3418北京市" 北京城区" BJCQ1101" 北京郊县" BJJX1102重庆市" 重庆城区" CQCQ5001" 重庆郊县" CQJX5002福建省" 福州市" FZS3501" 龙岩市" LYS3508" 宁德市" NDS3509" 南平市" NPS3507" 莆田市" PTS3503" 泉州市" QZS3505" 三明市" SMS3504" 厦门市" XMS3502" 漳州市" ZZS3506广东省" 潮州市" CZS4451" 东莞市" DGS4419" 东沙群岛" DSQD4421" 佛山市" FSS4406" 广州市" GZS4401" 河源市" HYS4416" 惠州市" HZS4413" 江门市" JMS4407" 揭阳市" JYS4452" 茂名市" MMS4409" 梅州市" MZS4414" 清远市" QYS4418" 韶关市" SGS4402" 汕头市" STS4405" 汕尾市" SWS4415" 深圳市" SZS4403" 云浮市" YFS4453" 阳江市" YJS4417" 珠海市" ZHS4404" 湛江市" ZJS4408" 肇庆市" ZQS4412" 中山市" ZSS4420甘肃省" 白银市" BYS6204" 定西市" DXS6211" 甘南藏族自治州" GNZZ6230 " 金昌市" JCS6203" 酒泉市" JQS6209" 嘉峪关市" JYGS6202" 陇南市" LNS6212" 临夏回族自治州" LXHZ6229" 兰州市" LZS6201" 平凉市" PLS6208" 庆阳市" QYS6210" 天水市" TSS6205" 武威市" WWS6206" 张掖市" ZYS6207广西壮族自治区" 北海市" BHS4505" 百色市" BSS4510" 崇左市" CZS4514" 防城港市" FCGS4506" 贵港市" GGS4508" 桂林市" GLS4503" 河池市" HCS4512" 贺州市" HZS4511" 来宾市" LBS4513" 柳州市" LZS4502" 南宁市" NNS4501" 钦州市" QZS4507" 梧州市" WZS4504" 玉林市" YLS4509贵州省" 安顺市" ASS5204" 毕节地区" BJDQ5224" 贵阳市" GYS5201" 六盘水市" LPSS5202" 黔东南苗族侗族自治州" QDNM5226" 黔南布依族苗族自治州" QNBY5227 " 黔西南布依族苗族自治州" QXNB5223 " 铜仁地区" TRDQ5222" 遵义市" ZYS5203河北省" 保定市" BDS1306" 承德市" CDS1308" 沧州市" CZS1309" 邯郸市" HDS1304" 衡水市" HSS1311" 廊坊市" LFS1310" 秦皇岛市" QHDS1303" 石家庄市" SJZS1301" 唐山市" TSS1302" 邢台市" XTS1305" 张家口市" ZJKS1307湖北省" 恩施土家族苗族自治州" ESTJ4228 " 鄂州市" EZS4207 " 黄冈市" HGS4211" 黄石市" HSS4202" 荆门市" JMS4208" 荆州市" JZS4210" 潜江市" QJS4292" 神农架林区" SNJL4294" 十堰市" SYS4203" 随州市" SZS4213" 天门市" TMS4293" 武汉市" WHS4201" 襄樊市" XFS4206" 孝感市" XGS4209" 咸宁市" XNS4212" 仙桃市" XTS4291黑龙江省" 大庆市" DQS2306" 大兴安岭地区" DXAL2327" 哈尔滨市" HEBS2301" 鹤岗市" HGS2304" 黑河市" HHS2311" 佳木斯市" JMSS2308" 鸡西市" JXS2303" 牡丹江市" MDJS2310" 齐齐哈尔市" QQHE2302" 七台河市" QTHS2309" 绥化市" SHS2312" 双鸭山市" SYSS2305" 伊春市" YCS2307海南省" 白沙黎族自治县" BSLZ4613" 保亭黎族苗族自治县" BTLZ4617 " 昌江黎族自治县" CJLZ4614 " 澄迈县" CMX4611" 定安县" DAX4609" 东方市" DFS4608" 儋州市" DZS4605" 海口市" HKS4601" 乐东黎族自治县" LDLZ4615" 临高县" LGX4612" 陵水黎族自治县" LSLZ4616" 南沙群岛" NSQD4620" 琼海市" QHS4604" 琼中黎族苗族自治县" QZLZ4618 " 三亚市" SYS4602" 屯昌县" TCX4610" 万宁市" WNS4607" 五指山市" WZSS4603" 西沙群岛" XSQD4619" 中沙群岛的岛礁及其海域" ZSQD4621 湖南省" 常德市" CDS4307" 长沙市" CSS4301" 郴州市" CZS4310" 怀化市" HHS4312" 衡阳市" HYS4304" 娄底市" LDS4313" 邵阳市" SYS4305" 湘潭市" XTS4303" 湘西土家族苗族自治州" XXTJ4331 " 岳阳市" YYS4306 " 益阳市" YYS4309" 永州市" YZS4311" 张家界市" ZJJS4308" 株洲市" ZZS4302河南省" 安阳市" AYS4105" 鹤壁市" HBS4106" 济源市" JYS4118" 焦作市" JZS4108" 开封市" KFS4102" 漯河市" LHS4111" 洛阳市" LYS4103" 南阳市" NYS4113" 平顶山市" PDSS4104" 濮阳市" PYS4109" 三门峡市" SMXS4112" 商丘市" SQS4114" 许昌市" XCS4110" 新乡市" XXS4107" 信阳市" XYS4115" 周口市" ZKS4116" 驻马店市" ZMDS4117" 郑州市" ZZS4101吉林省" 白城市" BCS2208" 白山市" BSS2206" 长春市" CCS2201" 吉林市" JLS2202" 辽源市" LYS2204" 四平市" SPS2203" 松原市" SYS2207" 通化市" THS2205" 延边朝鲜族自治州" YBCX2224 江苏省" 常州市" CZS3204" 淮安市" HAS3208" 连云港市" LYGS3207" 南京市" NJS3201" 南通市" NTS3206" 宿迁市" SQS3213" 苏州市" SZS3205" 泰州市" TZS3212" 无锡市" WXS3202" 徐州市" XZS3203" 盐城市" YCS3209" 扬州市" YZS3210" 镇江市" ZJS3211江西省" 抚州市" FZS3610" 赣州市" GZS3607" 吉安市" JAS3608" 景德镇市" JDZS3602 " 九江市" JJS3604" 南昌市" NCS3601" 萍乡市" PXS3603" 上饶市" SRS3611" 新余市" XYS3605" 宜春市" YCS3609" 鹰潭市" YTS3606辽宁省" 鞍山市" ASS2103" 本溪市" BXS2105" 朝阳市" CYS2113" 丹东市" DDS2106" 大连市" DLS2102" 抚顺市" FSS2104" 阜新市" FXS2109" 葫芦岛市" HLDS2114 " 锦州市" JZS2107" 辽阳市" LYS2110" 盘锦市" PJS2111" 沈阳市" SYS2101" 铁岭市" TLS2112" 营口市" YKS2108内蒙古自治区" 阿拉善盟" ALSM1529 " 包头市" BTS1502" 巴彦淖尔市" BYNE1508 " 赤峰市" CFS1504" 鄂尔多斯市" EEDS1506 " 呼和浩特市" HHHT1501 " 呼伦贝尔市" HLBE1507 " 通辽市" TLS1505" 乌海市" WHS1503" 乌兰察布市" WLCB1509 " 兴安盟" XAM1522" 锡林郭勒盟" XLGL1525宁夏回族自治区" 固原市" GYS6404" 石嘴山市" SZSS6402 " 吴忠市" WZS6403" 银川市" YCS6401" 中卫市" ZWS6405青海省" 果洛藏族自治州" GLZZ6326" 海北藏族自治州" HBZZ6322" 海东地区" HDDQ6321" 黄南藏族自治州" HNZZ6323" 海南藏族自治州" HNZZ6325" 海西蒙古族藏族自治州" HXMG6328 " 西宁市" XNS6301 " 玉树藏族自治州" YSZZ6327四川省" 阿坝藏族羌族自治州" ABZZ5132" 巴中市" BZS5119" 成都市" CDS5101" 德阳市" DYS5106" 达州市" DZS5117" 广安市" GAS5116" 广元市" GYS5108" 甘孜藏族自治州" GZZZ5133" 乐山市" LSS5111" 凉山彝族自治州" LSYZ5134" 泸州市" LZS5105" 眉山市" MSS5114" 绵阳市" MYS5107" 南充市" NCS5113" 内江市" NJS5110" 攀枝花市" PZHS5104" 遂宁市" SNS5109" 雅安市" YAS5118" 宜宾市" YBS5115" 自贡市" ZGS5103" 资阳市" ZYS5120山东省" 滨州市" BZS3716" 东营市" DYS3705" 德州市" DZS3714" 菏泽市" HZS3717" 济宁市" JNS3708" 济南市" JNS3701" 聊城市" LCS3715" 莱芜市" LWS3712" 临沂市" LYS3713" 青岛市" QDS3702" 日照市" RZS3711" 泰安市" TAS3709" 潍坊市" WFS3707" 威海市" WHS3710" 烟台市" YTS3706" 淄博市" ZBS3703" 枣庄市" ZZS3704上海市" 上海城区" SHCQ3101 " 上海郊县" SHJX3102 山西省" 长治市" CZS1404" 大同市" DTS1402" 晋城市" JCS1405" 晋中市" JZS1407" 临汾市" LFS1410" 吕梁市" LLS1411" 朔州市" SZS1406" 太原市" TYS1401" 忻州市" XZS1409" 运城市" YCS1408" 阳泉市" YQS1403陕西省" 安康市" AKS6109" 宝鸡市" BJS6103" 汉中市" HZS6107" 商洛市" SLS6110" 铜川市" TCS6102" 渭南市" WNS6105" 西安市" XAS6101" 咸阳市" XYS6104" 延安市" YAS6106" 榆林市" YLS6108天津市" 天津城区" TJCQ1201 " 天津郊县" TJJX1202 香港特别行政区" 北区" BQ8113" 大埔区" DBQ8114" 东区" DQ8103" 观塘区" GTQ8109" 黄大仙区" HDXQ8108 " 九龙城区" JLCQ8107 " 葵青区" KQQ8117" 离岛区" LDQ8118" 南区" NQ8104" 荃湾区" QWQ8110 " 深水埗区" SSBQ8106" 沙田区" STQ8116" 屯门区" TMQ8111" 湾仔区" WZQ8102" 西贡区" XGQ8115" 油尖旺区" YJWQ8105" 元朗区" YLQ8112" 中西区" ZXQ8101新疆维吾尔自治区" 阿克苏地区" AKSD6529" 阿拉尔市" ALES6592" 阿勒泰地区" ALTD6543" 博尔塔拉蒙古自治州" BETL6527" 巴音郭楞蒙古自治州" BYGL6528" 昌吉回族自治州" CJHZ6523" 哈密地区" HMDQ6522" 和田地区" HTDQ6532" 克拉玛依市" KLMY6502" 喀什地区" KSDQ6531" 克孜勒苏柯尔克孜自治州" KZLS6530 " 石河子市" SHZS6591 " 塔城地区" TCDQ6542" 吐鲁番地区" TLFD6521" 图木舒克市" TMSK6593" 五家渠市" WJQS6594" 乌鲁木齐市" WLMQ6501" 伊犁哈萨克自治州" YLHS6540西藏自治区" 阿里地区" ALDQ5425" 昌都地区" CDDQ5421" 拉萨市" LSS5401" 林芝地区" LZDQ5426" 那曲地区" NQDQ5424" 日喀则地区" RKZD5423" 山南地区" SNDQ5422云南省" 保山市" BSS5305" 楚雄彝族自治州" CXYZ5323" 德宏傣族景颇族自治州" DHDZ5331 " 大理白族自治州" DLBZ5329" 迪庆藏族自治州" DQZZ5334" 红河哈尼族彝族自治州" HHHN5325 " 昆明市" KMS5301" 临沧市" LCS5309" 丽江市" LJS5307" 怒江傈僳族自治州" NJLS5333 " 普洱市" PES5308" 曲靖市" QJS5303" 文山壮族苗族自治州" WSZZ5326 " 西双版纳傣族自治州" XSBN5328 " 玉溪市" YXS5304" 昭通市" ZTS5306浙江省" 杭州市" HZS3301" 湖州市" HZS3305" 金华市" JHS3307" 嘉兴市" JXS3304" 丽水市" LSS3311" 宁波市" NBS3302" 衢州市" QZS3308" 绍兴市" SXS3306" 台州市" TZS3310" 温州市" WZS3303" 舟山市" ZSS3309。
vue引入高德地图获取经纬度地址
vue引⼊⾼德地图获取经纬度地址1、在index.html引⼊⾼德地图<script type="text/javascript" src="https:///maps?v=1.4.4&key=your key"></script> //key找个适合例如:2、在webpack.base.conf.js 配置引⼊externals: {'AMap': 'AMap',}3、在vue⽂件中使⽤<template><div id="my_container"></div></template><script>import AMap from 'AMap'export default {name: "company_manage",data () {return {ruleForm: {name: '',phone: '',addr: '',long: '',lat: '',start_work_time: '',end_work_time: '',},}},mounted:function () {this.init()},methods: {init() {var map = new AMap.Map('my_container',{resizeEnable: true,zoom: 18,})AMap.plugin('AMap.Geolocation',function(){ //异步加载插件var geolocation = new AMap.Geolocation()map.addControl(geolocation)})var geocoder,marker;function regeocoder(lnglatXY,that) {AMap.plugin('AMap.Geocoder',function(){var geocoder = new AMap.Geocoder({radius: 1000,extensions: "all"});geocoder.getAddress(lnglatXY, function(status, result) {if (status === 'complete' && === 'OK') {var address = result.regeocode.formattedAddress;that.ruleForm.addr = address //兑换地址}});if(!marker){marker = new AMap.Marker();map.add(marker);}marker.setPosition(lnglatXY);})}var that = thismap.on('click', function(e) {var lnglatXY = [e.lnglat.getLng(),e.lnglat.getLat()]; regeocoder(lnglatXY,that)that.ruleForm.long = e.lnglat.getLng()t = e.lnglat.getLat()});},},}</script><style scoped>#my_container{margin-left: 140px;height: 400px;width: calc(100% - 140px);}</style>。
ELK收集nginx访问日志实战案例
ELK收集nginx访问⽇志实战案例⼀、Nginx的⽇志格式和⽇志变量Nginx跟Apache⼀样,都⽀持⾃定义输出⽇志格式,在进⾏Nginx⽇志格式定义前,先来了解⼀下关于多层代理获取⽤户真实IP的⼏个概念。
remote_addr:表⽰客户端地址,但有个条件,如果没有使⽤代理,这个地址就是客户端的真实IP,如果使⽤了代理,这个地址就是上层代理的IP。
X-Forwarded-For:简称XFF,这是⼀个HTTP扩展头,格式为 X-Forwarded-For: client, proxy1, proxy2,如果⼀个HTTP请求到达服务器之前,经过了三个代理 Proxy1、Proxy2、Proxy3,IP 分别为 IP1、IP2、IP3,⽤户真实IP为 IP0,那么按照 XFF标准,服务端最终会收到以下信息:X-Forwarded-For: IP0, IP1, IP2由此可知,IP3这个地址X-Forwarded-For并没有获取到,⽽remote_addr刚好获取的就是IP3的地址。
还要⼏个容易混淆的变量,这⾥也列出来做下说明:$remote_addr:此变量如果⾛代理访问,那么将获取上层代理的IP,如果不⾛代理,那么就是客户端真实IP地址。
$http_x_forwarded_for:此变量获取的就是X-Forwarded-For的值。
$proxy_add_x_forwarded_for:此变量是$http_x_forwarded_for和$remote_addr两个变量之和。
⼆、⾃定义Nginx⽇志格式在掌握了Nginx⽇志变量的含义后,接着开始对它输出的⽇志格式进⾏改造,这⾥我们仍将Nginx⽇志输出设置为json格式,下⾯仅列出Nginx配置⽂件nginx.conf中⽇志格式和⽇志⽂件定义部分,定义好的⽇志格式与⽇志⽂件如下:map $http_x_forwarded_for $clientRealIp {"" $remote_addr;~^(?P<firstAddr>[0-9\.]+),?.*$ $firstAddr;}log_format nginx_log_json'{"accessip_list":"$proxy_add_x_forwarded_for","client_ip":"$clientRealIp","http_host":"$host","@timestamp":"$time_iso8601","method":"$request_method","url":"$request_uri","status":"$status","http_re access_log /u01/nginx/logs/access.log nginx_log_json;定义完nginx⽇志格式后,重启nginx服务。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
NGUSERNAME [a-zA-Z\.\@\-\+_%]+ NGUSER %{NGUSERNAME} NGINXACCESS %{IPORHOST:clientip} - %{NGUSER:remote_user} \[%{HTTPDATE:timestam p}\] \"(?:%{WORD:verb} %{NOTSPACE:request}(?: HTTP/%{NUMBER:httpversion})?|%{DA TA:rawrequest})\" %{NUMBER:response} (?:%{NUMBER:bytes}|-) %{QS:referrer} %{QS: agent} %{NOTSPACE:http_x_forwarded_for}
"bytes" => "571", "clientip" => "123.67.69.249", "@version" => "1",
"host" => "controller", "http_x_forwarded_for" => "\"-\"",
"httpversion" => "1.1",
"timestamp" => "04/Jan/2017:14:21:54 +0800" }
"timezone" => "Asia/Shanghai", "ip" => "123.67.69.249",
"latitude" => 39.9289, "coordinates" => [ [0] 116.3883, [1] 39.9289 ], "continent_code" => "AS",
Indexer 配置: [root@mail etc]# cat logstash_nginx.conf input {
redis { host => "192.168.10.100" port => 6379 data_type => "list" key => "nginx"
} }
filter { grok { match => {"message" => "%{IPORHOST:clientip} \[%{HTTPDATE:timestam
} } output { if [type] == "nginx_access"{
redis { host => ["192.168.10.100:6379"] data_type =>"list" key => "nginx" }
} } ##说明:这里的 agent 只是做日志发送,对性能影响不大,读取 access.log 日志文件,并且 发送到远端 redis。
Agent 配置home/luohui/logstash-5.0.0/etc/logstashnginx.conf input {
file { path => ["/home/data/logs/access.log"] type => "nginx_access"
[0] 116.3883, [1] 39.9289 ], "postal_code" => nil,
"longitude" => 116.3883, "region_code" => "11" },
"verb" => "GET", "message" => "123.67.69.249 - - [04/Jan/2017:14:21:54 +0800] \ "GET /favicon.ico HTTP/1.1\" 404 571 \"-\" \"Mozilla/5.0 (Windows NT 6.1; WOW6 4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36\" \"-\"", "remote_user" => "-", "referrer" => "\"-\"", "@timestamp" => 2017-01-04T06:21:54.000Z, "response" => "404",
说明:由于可能我线上环境跟大家的日志生成格式不一样,这里主要列举大概配置,后续添 加统一配置:
log_format backend '$http_x_forwarded_for [$time_local] ' '"$host" "$request" $status $body_bytes_sent ' '"$http_referer" "$http_user_agent"'
####测试返回的结果: {
"request" => "/favicon.ico", "agent" => "\"Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKi
t/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36\"", "geoip" => {
4、 假如说我 nginx 日志在加上一个 nginx 响应时间呢?修改格式加上”request_time”: 4.1:修改日志结构生成数据:
log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for" $request_time
} } date { match => [ "timestamp" , "dd/MMM/YYYY:HH:mm:ss Z" ] } geoip { source => "clientip" target => "geoip" database => "/test/logstash-5.0.0/GeoLite2-City.mmdb" add_field => [ "[geoip][coordinates]", "%{[geoip][longitude]}" ] add_field => [ "[geoip][coordinates]", "%{[geoip][latitude]}" ] } mutate {
3、 先用 input 和 output 插件测试: [root@controller etc]# cat nginx.conf input{
stdin{} }
filter { grok { match => { "message" => "%{NGINXACCESS}" } } date { match => [ "timestamp" , "dd/MMM/YYYY:HH:mm:ss Z" ] } geoip { source => "clientip" target => "geoip" database => "/test/logstash-5.0.0/GeoLite2-City.mmdb" add_field => [ "[geoip][coordinates]", "%{[geoip][longitude]}" ] add_field => [ "[geoip][coordinates]", "%{[geoip][latitude]}" ] } mutate { convert => [ "[geoip][coordinates]", "float"] }
convert => [ "[geoip][coordinates]", "float"] }
} output {
elasticsearch { action => "index" hosts =>"192.168.10.100:9200" index => "logstash-nginx-%{+yyyy.MM.dd}" } }