geoserver遇到的问题分析,基于2.20.4版本

本文详细描述了GeoServer的启动过程,包括Servlet初始化、GeoserverInitStartupListener的使用,以及WFS请求处理中的问题。重点讨论了GeoTools的日志初始化和MySQL主键冲突在插入数据时的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

geoserver启动入口

org.geoserver.web.Start.main()

geoserver在servlet启动成功后的初始化入口

org.geoserver.GeoserverInitStartupListener.contextInitialized()

GeoTools.init((Hints) null); -- 初始化geotools log日志

src/web/app/src/main/webapp/WEB-INF/web.xml 文件配置了一系列容器listener

org.geoserver.GeoserverInitStartupListener

org.geoserver.logging.LoggingStartupContextListener

org.geoserver.platform.GeoServerContextLoaderListener

org.geoserver.platform.GeoServerHttpSessionListenerProxy

org.springframework.web.context.request.RequestContextListener

geoserver wfs 新增 InsertElementHandler.execute()

id的生成方式为gt-main.jar org.geotools.feature.FeatureBuilder.createDefaultFeatureId()

如果需要自己定义id可以在请求参数里面增加

<xsd:attribute default="UseExisting" name="idgen" type="wfs:IdentifierGenerationOptionType" use="optional"/>

取值有 UseExisting、ReplaceDuplicate、GenerateNew(默认)

具体可以参考 net.opengis.wfs.IdentifierGenerationOptionType

GenerateNew 生成一个新的id

UseExisting 使用用户设置的id

ReplaceDuplicate 使用用户设置的id,如果存在重复则生成新的id替换

请求入口

Dispatcher.handleRequestInternal()

//获取请求参数

request = init(request);

//获取处理请求的请求类

service = service(request);

loadServices();获取所有在spring xml文件中,注册了org.geoserver.platform.Service的对象

//获取请求类中对应的处理方法,并注入方法需要的参数

Operation operation = dispatch(request, service);

geoserver mysql插入数据时报错Column 'ID' specified twice

原因分析:

获取主键字段方法

jar包 org.geotools:gt-jdbc:26.4

PrimaryKeyFinder.getPrimaryKey()方法获取主键字段,

com.mysql.cj.jdbc.IterateBlock.doForAll() while循环里面断点分析:

先调用MetadataTablePrimaryKeyFinder.getPrimaryKey()在对应schema中获取schema中对应表的主键信息(对于mysql是获取不到的,因为页面无法配置schema)

如果获取不到,就调用HeuristicPrimaryKeyFinder.getPrimaryKey()在

ResultSet primaryKey = metaData.getPrimaryKeys(null, databaseSchema, tableName);

所有库中获取表对应的主键,

com.mysql.cj.jdbc.DatabaseMetaData.getPrimaryKeys()

此时如果2个库中有相同的表名,就会获取到2个主键id字段,导致生成的sql语句有问题,报错内容为:Column 'ID' specified twice

org.geotools.jdbc.JDBCDataStoreFactory.createDataStore()方法用于设置数据库连接信息,包含设置schema、设置主键对应的PrimaryKeyFinder类

geoserver获取配置的jdbc连接信息参数

org.geoserver.web.data.store.AbstractDataAccessPage.onSubmitInternal();

DataStoreInfo info = (DataStoreInfo) form.getModelObject(); -- 获取表单参数

org.geoserver.web.data.store.DataAccessEditPage.onSaveDataStore()

org.geoserver.catalog.ResourcePool.getDataStore()

请问在openlayers中如何删除Layer中的marker 3 在层中加了一个标记怎么永久的存到地图上 3 OpenLayers 如何设死地图边界 3 谁写过openlayers解析xml 3 openlayer.popup 3 OpenLayers 怎么做字段标注 4 字段标注不是用OL做的,而是你在SLD中定义用数据表的哪个字段做标签就可以了 4 OpenLayers 中画最短轨迹 4 使用TileCache配合OpenLayers 4 openlayers如何准确测距 9 openlayers简单实用例子 9 关于TileCache函数 13 openlayers 有函数说明的类图 14 go 14 Maker 一多,客户端就死掉 15 OpenLayers 怎么实现 AJAX 16 openlayer 要怎么研究才会应用得比较自如 16 改良OpenLayers的Popup 16 在openlayers的地图中要添加地图搜索功能一般采用什么方法 17 openlayers中如何访问geoserver发布的图片 18 什么是TMS? 18 怎样设置瓦片的大小 18 画一条线,数据量太大,怎么办? 18 怎么在图层上动态画点 20 GeoExt集成google map ,地图偏移 21 用JavaScript为OpenLayers.Marker的加上单击显示详细信息的功能 21 改良OpenLayers的MousePostion 25 使用OpenLayers实现一个在鼠标点击处添加标记的效果 27 openlayers 利用google maps的卫星地图 29 openLayers集成google map ,点标注错位 30 openlayers可以做出谷歌效果的地图吗? 31 用OpenLayers API和类来画点、线、面 32 OGC标准术语介绍WMS、WFS、WCS 35 如何控制地图的放缩 37 openLayers链接WMS的代码探讨 37 openlayers 2.5 矢量层在ie下闪烁的问题 38 openLayers 在地图上添加一个点并保存 39 openLayers 各个参数的意义 42 geoserver能搞出这种风格的图来吗? 43 关于SLD的线切割后的设置 43 GEOSERVE 标注铁路,使用 SLD 44 geoserver 发布.shp 中文乱码问题 怎么解决啊 45 Geoserver怎么连postGreSql 数据库 48 Geoserver连Oracle Spatial 52 GeoServer架构浅谈 53 Geoserver发布地图无法显示问题 57 WebGIS相关的OpenGIS规范 58 geoserver中地图以外的区域以自定义图片填充 62 怎样修改 geoServer 的用户名密码 65 GeoServer中的WMS服务生成的png图片背景色为透明 65 比例尺 65 需不需要一个layer对应一个store 66 如何部署shp 66 用GeoWebCache后Marker错位 66 标签太大导致不能显示? 67 geoserver把两个shapefile格式的图叠 67 GeoServer 能够集成 Google Map? 68 gwc地图切片的缓存路径在web.xml中设置么 68 如何实现地图查询? 68 sld文件怎么用 69 在sld中怎么控制路名的间隔? 69
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值