ベクター レイヤー (openlayers) で作成されたフィーチャを websocket 経由で 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)
どちらがよさそう...
助言がありますか?これを修正する方法が本当にわかりません。