如何在node.js中反序列化PHP会话?

时间:2015-09-12 23:50:24

标签: javascript php node.js session serialization

我将PHP $_SESSION数据存储在数据库中。

然后从Node.js服务器上我想获取该数据并对其进行反序列化。

我试图像这样使用js-php-unserialize

con.query('SELECT user_id, data ' + 
            'FROM sessions ' +
            'WHERE session_id = ? AND session_id IS NOT NULL AND user_id IS NOT NULL'
          , [tokenId] , function(queryError, rows){

    if(queryError){
      throw queryError;
    }

    console.log(rows[0].data);
    return;
    var data;

    if(rows[0]){
      data = PHPUnserialize.unserialize(rows[0].data);
      var now = Math.floor(new Date() / 1000);

      if(data.MA_IDLE_TIMEOUT < now){
        throw 'The session Times out!';
      }

      if(myIP != data.MA_IP_ADDRESS){
        throw 'This session have been hijacked!';
      }

但这会引发这个错误:

SyntaxError: Unknown / Unhandled data type(s): m
    at error (C:\Program Files\nodejs\node_modules\php-unserialize\php-unseriali
ze.js:54:13)
    at _unserialize (C:\Program Files\nodejs\node_modules\php-unserialize\php-un
serialize.js:166:11)
    at Object.unserialize (C:\Program Files\nodejs\node_modules\php-unserialize\
php-unserialize.js:173:10)
    at C:\Program Files\nodejs\app.js:41:25
    at Layer.handle [as handle_request] (C:\Program Files\nodejs\node_modules\ex
press\lib\router\layer.js:95:5)
    at next (C:\Program Files\nodejs\node_modules\express\lib\router\route.js:13
1:13)
    at Route.dispatch (C:\Program Files\nodejs\node_modules\express\lib\router\r
oute.js:112:3)
    at Layer.handle [as handle_request] (C:\Program Files\nodejs\node_modules\ex
press\lib\router\layer.js:95:5)
    at C:\Program Files\nodejs\node_modules\express\lib\router\index.js:277:22
    at Function.process_params (C:\Program Files\nodejs\node_modules\express\lib
\router\index.js:330:12)

以下是我尝试反序列化的数据:

MA_IP_ADDRESS|s:10:"10.0.4.195";MA_USER_AGENT|s:72:"Mozilla/5.0 (Windows NT 6.1;
 WOW64; rv:40.0) Gecko/20100101 Firefox/40.0";MA_IDLE_TIMEOUT|i:1442101764;

如何更正此问题?

1 个答案:

答案 0 :(得分:3)

使用.unserializeSession()代替.unserialize()