1

所以我一直在网上寻找一个好的 node.js Facebook 模板,但我真正能找到的是这个https://github.com/heroku/facebook-template-nodejs。它很不错,但它使用 express 2.4.6 和节点 0.6.x。我想跟上标准并在 express 3.x 和节点 0.8.x 中工作,但是如果我更新了,package.json我将无法再使用 heroku 模板附带的动态帮助器,主要是这些功能:

app.dynamicHelpers({
  'host': function(req, res) {
    return req.headers['host'];
  },
  'scheme': function(req, res) {
    return req.headers['x-forwarded-proto'] || 'http';
  },
  'url': function(req, res) {
    return function(path) {
      return app.dynamicViewHelpers.scheme(req, res) + app.dynamicViewHelpers.url_no_scheme(req, res)(path);
    }
  },
  'url_no_scheme': function(req, res) {
    return function(path) {
      return '://' + app.dynamicViewHelpers.host(req, res) + (path || '');
    }
  },
});

有谁知道我在哪里可以找到一些最新的信息?

4

1 回答 1

3

嗨,我遇到了同样的问题,要使其正常工作,需要进行多项更改:

首先你需要更新 package.json 中的依赖:

"dependencies": {
"async":     "0.1.x",
"ejs":       "0.8.x",
"express":   "3.1.x",
"faceplate": "0.4.x"
},

然后执行“npm install”以更新本地内容。

在 web.js 中的几个地方都需要进行下一次手术。对于我的设置,我需要更新顶部的“要求”列表:

var async   = require('async');
var express = require('express');
var util    = require('util');
var http = require('http');
var path =require('path');

然后在顶部注释掉旧的(2.x)风格的表达初始化。然后添加一个新的 3.x 兼容的:

var store  = new express.session.MemoryStore;
var app = express();

app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.set('view options', { pretty: true });
app.locals.pretty = true;
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.cookieParser('secret'));
app.use(express.session({ secret: 'secret', store: store }));
app.use(express.static(path.join(__dirname, 'public')));
app.use(require('faceplate').middleware({
    app_id: process.env.FACEBOOK_APP_ID,
    secret: process.env.FACEBOOK_SECRET,
    scope:  'user_likes,user_photos,user_photo_video_tags'
  }));

// fix dynamic helpers
app.use(function(req,res,next){
    res.locals.host =  req.headers['host'];
    res.locals.scheme = req.headers['x-forwarded-proto'] || 'http';
    res.locals.url_no_scheme =  function(path) {
                  return '://' + res.locals.host + path;
                };
    res.locals.url =  function(path) {
          return res.locals.scheme + res.locals.url_no_scheme(path);
        };

    next();
});
});

请注意,前面的块包含对您原始问题的修复。只需添加您自己的中间件,将这些变量/函数设置为 res.locals。此时您可以注释掉旧的 2.xapp.dynamicHelpers块。

添加 3.x 样式初始化:

var server = http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port')
  + ":" + app.get('env'));
});

此时问题已“解决”,但仍然无法正常工作。显然,用于面板的最新 API(可能是由于 FB 更改)已经有所改变。因此,在授权应用程序然后尝试呈现页面后,您会收到错误消息。这是由于函数中facebook.get回调的签名不正确handle_facebook_request,以及传递给回调的数据发生了变化。

所以以朋友为例:

...
function(cb) {
    // query 4 friends and send them to the socket for this socket id
    req.facebook.get('/me/friends', { limit: 4 }, function(friends) {
      req.friends = friends;
      cb();
    });
  },
...

应该改成这样:

...
function(cb) {
    // query 4 friends and send them to the socket for this socket id
    req.facebook.get('/me/friends', { limit: 4 }, function(dummy,friends) {
      req.friends = friends.data;
      cb();
    });
  },
...

对照片和喜欢重复此操作,您应该会很好。

于 2013-01-31T23:18:45.200 回答