我正在尝试通过 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) 
哪个看起来不错...
有什么建议么?我真的不知道如何解决这个问题。