- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试通过 websockets 将在矢量图层 (openlayers) 上创建的要素保存到 postgreSQL 9.1/postGIS 2.0。我正在使用 websockets,因为我要插入表单数据以及几何图形。
我的服务器是 NodeJS 0.10.12 和 pg 模块。
我正在尝试将要素的几何图形转换为字符串,将其从字母和括号中删除,然后仅将数字发送到服务器。我在服务器端收到关于几何的语法错误。
尽管尝试了很多东西和不同的语法,我还是无法修复它。
客户端(片段)
//create websockets
var so = new WebSocket("ws://localhost:8000");
//error report for websockets
so.onerror=function (evt)
{saveMSG.textContent = evt;}
//open websockets
so.onopen = function(){
//get geometry
var jak=map.layers[2].features[0].geometry;
//make it a string
var as=new String(jak);
//keep the numbers
var hul=as.substring(11,as.length-1);
//make it WKT
var god=hul.toString();
//send it with stringify/websockets
so.send(JSON.stringify({command: 'insertAll',
geo: god,
//send other things from the form....
服务器端
var packet = JSON.parse(msg.utf8Data);
switch (packet['command'])
{case 'insertAll':insertEm(packet['geo']) ;break;
//other cases here...call function according to case...
//so "insertAll" calls the following
function insertEm(geo){
//get client data, put them in place and create a string
var met="ST_GeomFromText('LINESTRING("+geo+")',900913)";
var pra=new String(met);
//connect to db and execute prepared statement
var conString = "pg://user:user@localhost:5432/myDB";
var client = new pg.Client(conString);
client.connect();
var query = client.query({name:"inser", text:"INSERT INTO pins(p_geom) values($1)", values:[pra]});
我得到错误: [error: parse error - invalid geometry] hint: '"ST"<-- parse error a position 2 within geometry']
所以我认为它的准备语句可能有问题?
我已将其切换为一个简单的查询,例如:
var query = client.query("INSERT INTO pins (p_geom) values('"+pra+"')")
我得到了错误
[error: syntax error at or near "LINESTRING"]
在我提出的查询结束时 query.on("end", function (result) {console.log(result);connection.send(pra); client.end();});
所以我可以看到客户端发送到服务器的内容。我明白了
ST_GeomFromText('LINESTRING(2335859.0225 4725430.1340625,2378933.155 4741356.7040625)',900913)
看起来不错...
有什么建议吗?我真的不知道如何解决这个问题。
最佳答案
使用此查询:
var query = client.query("INSERT INTO pins (p_geom) values('"+pra+"')")
你不应该引用 pra
。这将引用 ST_GeomFromText 函数调用,您提交的查询将类似于:
PostGIS 认为您正在尝试提交格式不正确的字符串,中间有未转义的单引号。
切换您的查询字符串生成器来执行此操作应该有效:
var query = client.query("INSERT INTO pins (p_geom) values("+pra+")")
但不要这样做
您现在正面临 SQL 注入(inject)攻击,因为有人可能会破解 HTTP 请求以发送一些偷偷摸摸的东西,而不是您期望的几何 WKT。不要使用字符串连接将来自 Web 浏览器的输入嵌入到数据库查询中,因为它会绕过框架的某些安全功能。
现在,回到您第一次尝试使用参数化查询:
node.js 库正在尝试准备您的参数以插入到数据库中,并将其视为字符串,用单引号将其括起来,并转义所有嵌入的单引号。这会导致查询发送到 PostGIS:
INSERT INTO pins(p_geom) values('ST_GeomFromText(''LINESTRING(2335859.0225 4725430.1340625,2378933.155 4741356.7040625)'',900913)')
然后 PostGIS 尝试通过解析将字符串转换为几何图形,并提示有效的几何图形不会以“ST”开头
不是将 ST_GeomFromText(...)
作为字符串参数传递,只需传递查询中真正是字符串的部分 - WKT。像这样:
var wkt = "LINESTRING("+geo+")";
var query = client.query('INSERT INTO pins(p_geom) values(ST_GeomFromText(?,900913))', [wkt])
关于node.js - 通过 nodejs 和 websockets 将功能从 openlayers 保存到 postgis,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18176424/
是否可以在使用 PHP 实现 API 后存储从网站 (Nestoria) 收集的数据?我可以使用 PHP 提取数据并将结果显示在网络浏览器上,但我需要将它们转储或保存到我的 PostGIS 数据库中。
我正在尝试清理 PostGIS 数据库中的一些地理空间数据。由于地理编码过程中的一些不精确性,一些必须落在特定区域边界内的点被映射到非常接近,但在该区域的定界多边形之外。 我的第一个方法是使用 Pos
我得到一列( latlon ),它是 ST_MultiPolygon . 另一个几何体是一个点,我只想检查它是否在我的 MultiPolygons 内。 我试过: SELECT ST_CONTAINS
我正在使用似乎过于分散而无法有效查询的 radio map 。当我询问一个点是否在多边形内时,响应时间为 20-40 秒(我已经测试了“内”/“包含”/“重叠”)。我使用 PostGIS 和 GeoD
所以我加载了一堆 NHD 数据,几何图形最终变成了 MultiPolygonZM(其他表格的 pointZM 和 areaZM) way geometry(MultiPolygonZM,90091
我需要 PostGIS 中地理数据中心的经度和纬度。格式称为 EPSG 2206,记录中的列是“length”、“shape_area”和“the_geom” 最佳答案 我使用查询来获取经度和纬度。
我正在将 GeoDjango 与 PostGIS 结合使用,并尝试使用多边形从数据库中获取属于其中的记录。 如果我定义一个大于地球面积一半的多边形,则假定多边形的“内部”是我打算作为“外部”的较小区域
我正在使用 ubuntu 12.04,我安装了 postgis2.1 和 postgresql9.1 ......我是所有人的新手!...... 我按照这个教程创建了一个模板数据库:http://li
我正在尝试将一系列线串几何图形与匹配属性(road_name_search 和 road_id)结合起来,然后将合并的线串从以下示例数据连接回 road_id 属性 http://sqlfiddle.
我计划将 GeoServer 与 PostGIS 数据库结合使用,以通过 Web map 服务提供等高线。 我有一个简单的经纬度值网格,我想将其存储在数据库中并绘制轮廓。虽然 GeoServer 用户
我正在尝试启动 GeoDjango 应用程序。我已经在 Lion 上使用 brew 安装了 Postgres 和 PostGIS。我使用 template_postgis 创建了一个数据库:creat
我正在尝试在 Ubuntu Server 12.04 上设置一个 tile 服务器,并且我已经安装了 Postgresql 和 PostGis 以及 Mapnik 和 Osm2pgsql。我正在尝试运
我正在迁移一个项目的连接模式从:使用DriverManager到DataDource。但我收到了这个错误: org.postgis.PGgeometry cannot be cast to org.p
我关注了这个tutorial on the Open shift site .我现在正在尝试添加自己的数据,但运气不佳。我在本地计算机上有一个由 PGAdmin III 管理的 postGIS 数据库
我在通过 geoservers wfs 将 ol3 中的功能发布到 postgis db 时遇到问题。当我运行此代码时,我只能插入 gid(pk) 和 bin 列,但_geom(Geometry) 列
我已经成功设置了一个用于 OSM-Bright 的 postgis 服务器。我必须承认服务器对我来说有点像黑盒子,所以虽然我已经设置好它并且运行良好,但我不知道如何以最佳方式使用它。 在 OSM-Br
我想从 Java 查询 PostGIS/PostgreSQL 数据库。 已安装 PostgreSQL 9.4。 PostGIS 2.1 Bundle for PostgreSQL 9.4 通过 Sta
从 PostGIS 2.1 升级:“错误:尝试重新定义参数“postgis.backend” 我正在尝试升级 AWS RDS 上的 PostGIS 数据库,但在运行 ALTER EXTENSION p
我尝试使用 pgAdmin 4 在 Postgresql 11 上运行 postgis 扩展,但在尝试创建扩展时出现以下错误: Could not access file "$libdir/postg
今天当我尝试从包含几何值的列中进行选择时,我随机开始出现此错误 错误:无法访问文件“$libdir/postgis-2.0” 我的选择之前一直运行良好,但今天才开始出现这种情况。有关如何解决此问题的任
我是一名优秀的程序员,十分优秀!