私はNode.jsに基づいてチャットアプリケーションを作ろうとしています。私はWebSocketサーバー(wsライブラリ)をExpressJSセッションシステムを使用するように強制したいと思います。残念ながら、私は立ち往生している。セッションのデータを取得するために使用されるMemoryStoreハッシュは、CookieのセッションIDとは異なります。誰かが私が間違っていることを私に説明することができましたか?ExpressJS&ウェブソケットとセッション共有
のWebSocketサーバコード部:
module.exports = function(server, clients, express, store) {
server.on('connection', function(websocket) {
var username;
function broadcast(msg, from) {...}
function handleMessage(msg) {...}
express.cookieParser()(websocket.upgradeReq, null, function(err) {
var sessionID = websocket.upgradeReq.cookies['sid'];
//I see same value in Firebug
console.log(sessionID);
//Shows all hashes in store
//They're shorter than sessionID! Why?
for(var i in store.sessions)
console.log(i);
store.get(sessionID, function(err, session) {
websocket.on('message', handleMessage);
//other code - won't be executed until sessionID in store
websocket.on('close', function() {...});
});
});
});
}
ストアオブジェクト定義:
var store = new express.session.MemoryStore({
reapInterval: 60000 * 10
});
アプリ構成:メインコードの
app.configure(function() {
app.use(express.static(app.get("staticPath")));
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({
store: store,
secret: "dO_ob",
key: "sid"
}));
});
パート:
var app = express();
var httpServer = http.createServer(app);
var websocketServer = new websocket.Server({server: httpServer});
httpServer.listen(80);
サンプルデバッグ出力:
- websocket.upgradeReq.headers.cookie "sid=s%3A64a%2F6DZ4Mab8H5Q9MTKujmcw.U8PJJIR%2BOgONY57mZ1KtSPx6XSfcn%2FQPZ%2FfkGwELkmM"
- websocket.upgradeReq.cookies["sid"] "s:64a/6DZ4Mab8H5Q9MTKujmcw.U8PJJIR+OgONY57mZ1KtSPx6XSfcn/QPZ/fkGwELkmM"
- i "64a/6DZ4Mab8H5Q9MTKujmcw"
シンプルな、醜い回避策が役立ちます:セッションID = sessionID.match(/:[-ZA-Z0-9/+] + \ ./)[0]。スライス(1、-1)ですが、私はこの問題を解決したいと思います。 – skorczan
回避策をお寄せいただきありがとうございました:)これに適切な解決策を見つけましたか? – Tim