/ / Dlaczego nie wymaga zestawu sesji z node.js - javascript, node.js, oauth, express

Dlaczego zestaw pytań nie jest ustawiony na node.js - javascript, node.js, oauth, express

Nie mogę nic ustawić

req.session

Próbuję zapisać token i klucz tajny w sesji, aby móc je sprawdzić po wywołaniu zwrotnym autoryzacji. Oto mój kod

var express = require("express"),
app     = express(),
server  = require("http").createServer(app),
io      = require("socket.io").listen(server),
oauth   = require("oauth"),
tumblr  = require("tumblr.js"),
client  = {
consumer_key: "1n9fMPxCBFBbcIGRImYKSK5wwDL6yux64S4DxEwiwzHTNuaIoD",
consumer_secret: "bW9YKbnwgxexyVx1AaxQr1QoemEkjd29p5U1WpbZ8r1XEH41C0"
},
consumer = new oauth.OAuth(
"http://www.tumblr.com/oauth/request_token", "http://www.tumblr.com/oauth/access_token",
client.consumer_key, client.consumer_secret, "1.0A", "http://127.0.0.1:8080/sessions/callback", "HMAC-SHA1");

server.listen(1337);

app.configure("dev", function(){
app.use(express.logger());
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: "topsecret" }));
});


app.get("/home", function(req, res){
consumer.getOAuthRequestToken(function(err, oauth_token, oauth_token_secret, results){
if(err){
console.log(err);
}else{
//req.session.oauth.token = oauth_token;
console.log("oauth.token: " + oauth_token);
//req.session.oauth.token_secret = oauth_token_secret;
console.log("oauth.token_secret: " + oauth_token_secret);
res.redirect("http://www.tumblr.com/oauth/authorize?oauth_token="+oauth_token);
}
});
});

app.get("/oauth/testapp", function(req, res){
res.send("callback");
});

Kiedy odkomentuję

req.session.oauth.token = oauth_token;

Pojawia się błąd „nie można odczytać właściwości„ oauth ”undefined” również req.session wyświetla niezdefiniowane w konsoli.

Odpowiedzi:

2 dla odpowiedzi № 1

Próbujesz ustawić właściwość token na obiekcie oauth na sesji. Jeśli… oauth obiekt nie zostanie zainicjowany, będzie undefined, i nie można ustawić token atrybut. Najpierw musisz zainicjować oauth obiekt w sesji. Możesz na przykład zrobić

req.session.oauth = {token: theToken}

Spowoduje to utworzenie obiektu w sesji i ustawienie token właściwość tego obiektu.

@robertklep wymyślił drugą połowę rozwiązania: upewnij się, że działasz w odpowiednim środowisku. dev w app.configure, musisz uruchomić węzeł z NODE_ENV=dev do zastosowania konfiguracji.


2 dla odpowiedzi nr 2
var app = express();
app.configure("dev", function() {
app.use(express.logger());
app.use(express.bodyParser());
app.use(express.cookieParser());
app.use(express.session({ secret: "topsecret" }));
app.use(app.router); // You need to add the router after the express.session
});

mam nadzieję, że to może ci pomóc