2017-06-12 56 views
2

介绍节点JS主要功能外使用变量和函数设定顺序

我有三个功能,每一个将数据馈送到下一个接着。目标首先是检索数据,然后验证API密钥,然后最终使用生成的API密钥和从第一个函数发布到第三个函数中的API的数据检索。

订购

  1. 第一功能函数从后检索数据。

  2. 第二个函数获取API请求的API密钥。

  3. 第三个函数将数据发布到API。

所需的功能

我需要在第一功能和第二功能生成的API密钥可用于第三功能使用重试的变量。没有被发现

问题和疑问

  • emailUser第三功能
  • api_key没有在第三个功能被发现使用
  • 还的功能需要,以便先运行,然后第二个

这一切都适用,如果我要插入数据手册,但当输入变量时它不起作用,我知道这是因为变量在函数内,但我该如何解决这个问题,我该如何设置函数的顺序?

的完整代码

// Grab the packages needs and sets server 
//---------------------------------- Grab the packages we need and set variables -------------------------------------------------- 
// -------------------------------------------------------------------------------------------------------------------------------- 
var express = require('express'); 
var request = require('request'); 
var nodePardot = require('node-pardot'); 
var bodyParser = require('body-parser'); 
var app = express(); 
var port = process.env.PORT || 8080; 

// Varibles to use in second and third function 
var password = 'password'; 
var userkey = '6767712'; 
var emailAdmin = '[email protected]'; 
// start the server 
app.listen(port); 
app.use(bodyParser.json()); // support json encoded bodies 
app.use(bodyParser.urlencoded({extended: true})); // support encoded bodies 
console.log('Server started! At http://localhost:' + port); 

// First Retrieve posted data from Front-End 
//---------------------------------- Retrieve posted data from Front-End ----------------------------------------------------- 
// --------------------------------------------------------------------------------------------------------------------------- 
// POST http://localhost:8080/api/index 
app.post('/api/data', function (req, res) { 
    console.log(req.body); 
    var Fname = req.body.fname; 
    var Lname = req.body.lname; 
    var emailUser = req.body.email; 
    res.send(Fname + ' ' + Lname + ' ' + emailUser); 
}); 

app.get('/', function (req, res) { 
    res.send('hello world, Nothing to see here...'); 
}); 

// Second Get Posted variables 
//---------------------------------- Now authenticate the api and get api_key ----------------------------------------------------- 
// -------------------------------------------------------------------------------------------------------------------------------- 
nodePardot.PardotAPI({ 
    userKey: userkey, 
    email: emailAdmin, 
    password: password, 
    // turn off when live 
    DEBUG: true 
}, function (err, client) { 
    if (err) { 
     // Authentication failed 
     // handle error 
     console.error("Authentication Failed", err) 
    } else { 
     // Authentication successful 
     // gets api key 
     var api_key = client.apiKey; 
     console.log("Authentication successful !", api_key); 
    } 
}); 

// Third Retrieve posted data from Front-End 
//---------------------------------- Send all data to API ----------------------------------------------------- 
// ------------------------------------------------------------------------------------------------------------ 
// Set the headers 
var headers = { 
    'User-Agent':  'Super Agent/0.0.1', 
    'Content-Type':  'application/x-www-form-urlencoded' 
}; 

// Configure the request 
var options = { 
    url: 'https://pi.pardot.com/api/prospect/version/4/do/create/email', 
    method: 'POST', 
    headers: headers, 
    form: { 
     'email': emailUser, 
     'user_key': userkey, 
     'api_key': api_key 
    } 
}; 

// Start the request 
request(options, function (error, response, body) { 
    if (!error && response.statusCode == 200) { 
     // Print out the response body 
     console.log("error",body) 
    } 
    else { 
     console.log("Sent Data",body); 
    } 
}); 

回答

1
使用 async包(带 npm install async安装)

最好的方式,是非常著名的和有用的包npm的功能将是这样的:

var async=require('async'); 

var handler = function (req,res) { 
async.auto 
(
{ 
    getBody: function (cb, results) { 
    var body=req.body; 
    //prepare body here then send it to next function 
    cb(null, body) 
    }, 
    getApi: ['getBody', function (results, cb) { 
    var preparedBody=results.getBody; 
    // get the api here and send it to next function 
    var apiKey=getApi() 
    cb(null, {apiKey:apiKey,preparedBody:preparedBody}) 

    }], 
    third: ['getApi', function (results, cb) { 
    var preparedBody=results.getApi.preparedBody; 
    var apiKey=results.getApi.apiKey; 
     // now data are here 
     cb(null,true) 
    }] 
}, 
function (err, allResult) { 
    // the result of executing all functions goes here 
} 
) 
} 
+0

谢谢你,依然有新的节点,以便在学习。我实施这个测试然后让你知道。 – Beep

+0

ok @Beep;但你问一个很好的问题;) – farhadamjady

+0

谢谢,这是一个很好的答案我只是想实现它atm – Beep

0

解决此问题的另一种方法是允许express middleware flow在单独的Router上为您执行这些操作。

我已经设置了一个sample Glitch供您参考使用stand in函数来模拟网络调用HERE

在你的情况,你会做这样的事情:

//API route 
var express = require('express'); 
var router = express.Router(); 

router.post('/data', function (req, res, next) { 
    console.log(req.body); 
    req.bundledData = {}; 
    req.bundledData.fname = req.body.fname; 
    req.bundledData.lname = req.body.lname; 
    req.bundledData.emailUser = req.body.email; 
    next(); 
}); 
router.use(function(req, res, next){ 
    nodePardot.PardotAPI({ 
     userKey: userkey, 
     email: emailAdmin, 
     password: password, 
     // turn off when live 
     DEBUG: true 
    }, function (err, client) { 
     if (err) { 
      // Authentication failed 
      // handle error 
      console.error("Authentication Failed", err) 
     } else { 
      // Authentication successful 
      // gets api key 
      req.bundledData.api_key = client.apiKey; 
      console.log("Authentication successful !", api_key); 
      next(); 
     } 
    }); 
}); 

router.use(function(req, res, next){ 
    // Set the headers 
    var headers = { 
     'User-Agent':  'Super Agent/0.0.1', 
     'Content-Type':  'application/x-www-form-urlencoded' 
    }; 

    // Configure the request 
    var options = { 
     url: 'https://pi.pardot.com/api/prospect/version/4/do/create/email', 
     method: 'POST', 
     headers: headers, 
     form: { 
      'email': emailUser, 
      'user_key': userkey, 
      'api_key': api_key 
     } 
    }; 

    // Start the request 
    request(options, function (error, response, body) { 
     if (!error && response.statusCode == 200) { 
      // Print out the response body 
      console.log("error",body) 
     } 
     else { 
      console.log("Sent Data",body); 
      //Processing is complete 
      res.json({ 
       success:true, 
       body:body 
      }); 
     } 
    }); 
}); 
+0

嗯,看起来整洁。现在去吃午饭,但是在不幸地探索了两种选择之后,谢谢。 – Beep