2015-06-07 10 views
6

Ich benutze nkzawa socket.io android client. Wie kann ich es mit dem Server sails.js verbinden? habe ich versucht, die Ansätze von Sending Socket request from Client (iOS & Android) to Sails.js Server und Simple Sails.js and Android Example aber ich erhalte die folgenden Fehler auf meinem Segel-Server:verbinden Android Client zu sails.js

Running "watch" task 
Waiting... 
verbose: A socket is being allowed to connect, but the session could not be loaded. Will create an empty, one-time session to use for the life of the socket connection. Details: 
Error: Session could not be loaded 
    at _createError (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/lib/hooks/session/index.js:271:21) 
    at Immediate._onImmediate (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/lib/hooks/session/index.js:274:13) 
    at processImmediate [as _immediateCallback] (timers.js:358:17) { [Error: Session could not be loaded] code: 'E_SESSION' } 
verbose: A socket is being allowed to connect, but the session could not be loaded. Will create an empty, one-time session to use for the life of the socket connection. Details: 
Error: Session could not be loaded 
    at _createError (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/lib/hooks/session/index.js:271:21) 
    at Immediate._onImmediate (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/lib/hooks/session/index.js:274:13) 
    at processImmediate [as _immediateCallback] (timers.js:358:17) { [Error: Session could not be loaded] code: 'E_SESSION' } 
verbose: Could not fetch session, since connecting socket has no cookie (is this a cross-origin socket?) 
Generated a one-time-use cookie:sails.sid=s%3AZfXLqUZt5kQ4M0hPd-NI6-0AzciPjXDf.IjhbWcteKvKB9h5v0kcxYRis8Lo1JhpTHN9eTweXpdwand saved it on the socket handshake. 
This will start this socket off with an empty session, i.e. (req.session === {}) 
That "anonymous" section will only last until the socket is disconnected unless you persist the session id in your database, 
or by setting the set-cookie response header for an HTTP request that you *know* came from the same user (etc) 
Alternatively, just make sure the socket sends a `cookie` header or query param when it initially connects. 
verbose: Could not fetch session, since connecting socket has no cookie (is this a cross-origin socket?) 
Generated a one-time-use cookie:sails.sid=s%3AFOsga3uhvU0N-CZsgAPAjY_IWZlGb5Cr.%2FjoQX1LkUU0OWeB1Kt3pr7cbFFOkMAirJ5ODPLwXgNAand saved it on the socket handshake. 
This will start this socket off with an empty session, i.e. (req.session === {}) 
That "anonymous" section will only last until the socket is disconnected unless you persist the session id in your database, 
or by setting the set-cookie response header for an HTTP request that you *know* came from the same user (etc) 
Alternatively, just make sure the socket sends a `cookie` header or query param when it initially connects. 
verbose: Receiving incoming message from Socket.io: [ { url: '/user/new' } ] 
error: Error (SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ):: Failed to parse incoming socket.io request. 
    at new constructor (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/standalone/create-error-constructor.js:38:16) 
    at Errorpack.factory [as PARSE_VIRTUAL_REQ] (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/standalone/create-error-factory.js:34:12) 
    at respondWithParseError (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/receive-incoming-sails-io-msg.js:247:29) 
    at receiveIncomingSailsIOMsg (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/receive-incoming-sails-io-msg.js:41:14) 
    at Socket.<anonymous> (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/on-connect.js:84:9) 
    at Socket.emit (events.js:107:17) 
    at Socket.onevent (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/socket.js:330:8) 
    at Socket.onpacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/socket.js:290:12) 
    at Client.ondecoded (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/client.js:193:14) 
    at Decoder.Emitter.emit (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/index.js:134:20) 
    at Decoder.add (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/socket.io-parser/index.js:247:12) 
    at Client.ondata (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/client.js:175:18) 
    at Socket.emit (events.js:107:17) 
    at Socket.onPacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/engine.io/lib/socket.js:99:14) 
    at WebSocket.emit (events.js:129:20) 
    at WebSocket.Transport.onPacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/engine.io/lib/transport.js:91:8) { [Error (SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ):: Failed to parse incoming socket.io request.] 
    code: 'SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ', 
    name: 'Error (SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ):', 
    status: 400, 
    message: 'Failed to parse incoming socket.io request.', 
    stack: 'Error (SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ):: Failed to parse incoming socket.io request.\n at new constructor (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/standalone/create-error-constructor.js:38:16)\n at Errorpack.factory [as PARSE_VIRTUAL_REQ] (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/standalone/create-error-factory.js:34:12)\n at respondWithParseError (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/receive-incoming-sails-io-msg.js:247:29)\n at receiveIncomingSailsIOMsg (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/receive-incoming-sails-io-msg.js:41:14)\n at Socket.<anonymous> (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/lib/on-connect.js:84:9)\n at Socket.emit (events.js:107:17)\n at Socket.onevent (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/socket.js:330:8)\n at Socket.onpacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/socket.js:290:12)\n at Client.ondecoded (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/client.js:193:14)\n at Decoder.Emitter.emit (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/socket.io-parser/node_modules/component-emitter/index.js:134:20)\n at Decoder.add (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/socket.io-parser/index.js:247:12)\n at Client.ondata (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/lib/client.js:175:18)\n at Socket.emit (events.js:107:17)\n at Socket.onPacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/engine.io/lib/socket.js:99:14)\n at WebSocket.emit (events.js:129:20)\n at WebSocket.Transport.onPacket (/usr/local/node-v0.12.4-linux-x64/lib/node_modules/sails/node_modules/sails-hook-sockets/node_modules/socket.io/node_modules/engine.io/lib/transport.js:91:8)', 
    details: 'No url provided in request: [object Object]' } 

Das ist mein Android-Client:

JSONArray arr = new JSONArray(); 
JSONObject obj = new JSONObject(); 
try { 
    obj.put("url", "/user/new"); 
} catch (JSONException e) { 
    e.printStackTrace(); 
} 
arr.put(obj); 
socket.emit("get", arr); 
+0

Wie erstellen Sie Ihre Socket-Instanz? Wie sieht die URL aus? –

+0

Ich erstelle oder öffne keine Sockets. Durch die Suche habe ich entdeckt, dass Segel diese Funktion haben, die auf regulären Routen die 'socket.io' Verbindung unterstützt. – pjsofts

+0

Ich bekomme den gleichen Fehler, haben Sie es geschafft, diesen Fehler zu beheben? – jaumard

Antwort

0

Im Objekt, das Sie zu emittieren haben gebaut Der Server, der den JSONArray-Wrapper überspringt, sollte das Problem beheben. Ändern Sie den Code wie folgt:

Wenn das Problem weiterhin besteht, gibt es einen anderen Bereich, der untersucht werden kann.

Socket-io wird das Problem der Analyse virtueller Anfrage stellen, wenn die Client-ID niedriger als 0.11.0 ist. Eine Lösung hierfür ist die Bearbeitung der Datei parse-sdk-metadata.js, die je nach Ihrer NPM-Version in /node_modules/sails-hook-sockets/lib/oder/node_modules/sails/node_modules/sails-hook-sockets/lib/ gefunden werden kann.

Darin ändern folgendes:

if (!(handshake.headers[SDK_META_PARAMS.version] || handshake.query[SDK_META_PARAMS.version])) { 
      handshake.query[SDK_META_PARAMS.version] = '0.9.0'; 
} 

TO:

if (!(handshake.headers[SDK_META_PARAMS.version] || handshake.query[SDK_META_PARAMS.version])) { 
      handshake.query[SDK_META_PARAMS.version] = '0.11.0'; 
} 

Dies sollte die Error (SAILS:HOOK:SOCKETS:PARSE_VIRTUAL_REQ) lösen, die Sie erhalten!