开源GIS学习:boundlessgeo官方案例“Building an Autocomplete Parcel Lookup”学习

本文主要是介绍开源GIS学习:boundlessgeo官方案例“Building an Autocomplete Parcel Lookup”学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   boundlessgeo官方网站提供了一些很好的开源gis案例,但有些部署需要它们的开源gis套件,但是我们可能并不想安装该套件,而且我试过,在下载时会很慢,这时,在学习这些案例时可能会碰到一些问题,本文记录了我在学习Building an Autocomplete Parcel Lookup该案例(http://workshops.boundlessgeo.com/tutorial-autocomplete/)时碰到的一些问题以及对应的解决方法。
  首先,数据的下载,导入,发布等步骤按照教程一步步做基本没有问题,注意创建数据库时一定要运行“create extension postgis”,使得postgis插件生效。
  问题主要发生在前端与geoserver交互的过程,官方网站已经提供了前端网页代码及对应的依赖,在未安装套件的情况下,可能需要注意的有:

1. index.html页面

-前端把app包下的Popup.js及LayersControl.js包含在“head”标签下

<script src="src/app/Popup.js"></script>
<script src="src/app/LayersControl.js"></script>

-“body”下app.js引用位置保证正确

<script src="src/app/app.js"></script>

2. app.js页面

-url地址补全,务必把http协议名加上

var url = 'http://localhost:9090/geoserver/ows?';

-openlayer底图来源为“MapQuest“,但在加载时总报错,因此先注释掉,需要可以试试其它来源底图,不要把自己发布的底图也注释掉。

  layers: [// MapQuest streets// new ol.layer.Tile({// title: 'Street Map',// group: "background",// source: new ol.source.MapQuest({layer: 'osm'})// }),// MapQuest imagery// new ol.layer.Tile({// title: 'Aerial Imagery',// group: "background",// visible: false,// source: new ol.source.MapQuest({layer: 'sat'})// }),// MapQuest hybrid (uses a layer group)// new ol.layer.Group({// title: 'Imagery with Streets',// group: "background",// visible: false,// layers: [// new ol.layer.Tile({// source: new ol.source.MapQuest({layer: 'sat'})// }),// new ol.layer.Tile({// source: new ol.source.MapQuest({layer: 'hyb'})// })// ]// }),new ol.layer.Tile({title: layerTitle,source: wmsSource,// TUTORIAL CHANGE #10opacity: 0.6// !TUTORIAL CHANGE #10}),highlight]

3. 跨域问题
  在实现地址自动填充以及点击查询时,都需要与geoserver交互会出现“No ‘Access-Control-Allow-Origin’ header is present on the requested resource. Origin ‘null’ is therefore not allowed access.”错误。在尝试了多种方法后,发现用”jsonp”方法请求可以解决该问题。
   在实现地址自动填充时, 参照geoserver关于wfs服务输出格式的帮助将app.js下wfsParams下“outputFormat”修改为’text/javascript’实现jsonp请求,默认callback参数为parseResponse。然后对应修改ajax请求数据类型为“jsonp”,并添加“jsonpCallback”参数。
需要注意,要实现jsonp支持,需要配置“ENABLE_JSONP”全局环境变量,设置值为true,参照:http://docs.geoserver.org/latest/en/user/services/wms/global.html#wms-global-variables

var wfsParams = {service: 'WFS',version: '2.0.0',request: 'GetFeature',typeName: 'county:address_autocomplete',outputFormat: 'text/javascript',srsname: 'EPSG:3857',viewparams: viewParamsStr};$.ajax({url: url,data: wfsParams,type: "GET",dataType: "jsonp",jsonpCallback:"parseResponse",

地址自动填充

   点击地图查询时,需要与geoserver WMS GetFeatureInfo服务交互,也会产生跨域问题,原来程序采用gml格式交互,因为不知道怎么样实现跨域,因此改为jsonp方式。

   //原来gml:infoFormat = 'application/vnd.ogc.gml/3.1.1'; //修改jsonp格式:infoFormat = 'text/javascript'; //原来gml格式:var format = new ol.format.GML({featureNS: featureNS, featureType: featureType});//修改为geojson格式:var format= new ol.format.GeoJSON({defaultDataProjection: "EPSG:3857"});//ajax方法,添加dataType和jsonpCallback参数:$.ajax({url: url,type: "GET",dataType: "jsonp",jsonpCallback:"parseResponse",...

这里写图片描述

   以上问题对于大佬来说可能很容易解决,但是对于萌新来说,一步步解决问题还是有点成就感的,当然,直接方法是避免产生跨域问题。

这篇关于开源GIS学习:boundlessgeo官方案例“Building an Autocomplete Parcel Lookup”学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/154134

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]