javascript - Node.js 中间件内部的异步调用?

标签 javascript node.js asynchronous

我需要通过查看 Redis 数据库内的 session 并检查是否存在需要异步调用的值来进行身份验证,当我在异步函数内传递返回类型时,我会得到未定义的返回。

req.isAuthenticated = function() {

  var cookies;
  if(this.headers.cookie) {
    var secrets = require('./config/secrets');
    cookies = cookie.parse(this.headers.cookie);
  }

  // TODO: Maybe figure out how to use this once
  var redisSessionClient = redis.createClient({host:'redis://127.0.0.1/0'});

  // if PHP generated a cookie
  if(cookies['PHPSESSID']) {

    // get the client PHP cookie id
    var sid = cookieParser.signedCookie(cookies['PHPSESSID'], secrets.sessionSecret);

    // get session information inside redis database
    redisSessionClient.get('my_session:'+sid, function(err, session, callback) {

      if(err)
        console.log("error : "+err);
        return err;

      var serializedSession = PHPUnserialize.unserializeSession(session);
      if(serializedSession._sf2_attributes._security_main) {
        console.log('should return true');
        return true; // I want to return here!
      } else {
        console.log('should return false');
        return false; // I want to return here!
      }

    });

    console.log('redisSessionClient is async cant return inside that block');
    // THIS IS BAD, BUT A TEMP HACK, NEED TO CHECK REDIS FIRST BUT ITS ASYNC
    // THIS MEANS AS LONG AS THERE IS A COOKIE WITH THE NAME PHPSESSID THE USER
    // CAN ACCESS LOGGED IN STUFF, THE CONDITION ABOVE READS THE SESSION FROM
    // THE REDIS SESSION STORE AND MAKE SURE THE COOKIE HAS A PARTICULAR VALUE
    return false;

  } else {
    console.log('should return false')
    return false;
  }
};

更新:

req.isAuthenticated = function() {

  var cookies, self = this;
  if(this.headers.cookie) {
    var secrets = require('./config/secrets');
    cookies = cookie.parse(this.headers.cookie);
  }

  // TODO: Maybe figure out how to use this once
  var redisSessionClient = redis.createClient({host:'redis://127.0.0.1/0'});

  // if PHP generated a cookie
  if(cookies['PHPSESSID']) {

    // get the client PHP cookie id
    var sid = cookieParser.signedCookie(cookies['PHPSESSID'], secrets.sessionSecret);

    // get session information inside redis database
    function doCall(callback) {
      redisSessionClient.get('my_Sess:'+sid, function(err, session) {

        if(err) {
          console.log("error : "+err);
          return;
        }

        var serializedSession = PHPUnserialize.unserializeSession(session);
        if(serializedSession._sf2_attributes._security_main) {
          console.log('should return true');
          return callback(true);
        } else {
          console.log('should return false');
          return callback(false);
        }

      });
    }

    doCall(function(response){
      return response;
    });


  } else {
    console.log('should return false')
    return false;
  }
};

这是完整的解决方案 https://jsfiddle.net/Lytsp8e2/1/

最佳答案

req.isAuthenticated = function(cb) {
  // ..........
  if(serializedSession._sf2_attributes._security_main) {
    console.log('should return true');
    cb(true); // I want to return here!
  } else {
    console.log('should return false');
    cb(false); // I want to return here!
  }

还有

if(err)
    console.log("error : "+err);
    return err;

应该是

if(err) {
    console.log("error : "+err);
    return err;
}

这是完整的解决方案https://jsfiddle.net/Lytsp8e2/2/保留大部分编码。

关于javascript - Node.js 中间件内部的异步调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31445944/

相关文章:

javascript - 我想使用 Angular js 根据特定的时间和日期在 ionic 中进行本地通知

jquery - 如何制作以Flipkart或Amazon相同的方式加载的Web应用程序?

java - 在 Android 中提取我的 JSON 结果

Django + 执行异步进程?

javascript - 尝试访问数组: family[i] is undefined

javascript - 通过 Controller 操作 zf2 附加 javascript

javascript - 使用 ng-style 根据 angularjs 条件添加背景或不添加背景

javascript - 在 node.js 中产生一个子进程

node.js - 从 node.js 脚本禁用 sudo/root 权限

c# - 如何从 Prism 事件聚合器订阅者中调用异步方法?