1

Node で追跡システムを構築していますが、追跡スクリプトを使用するサード パーティが Node アプリに接続する方法を理解するための助けが必要です。

最初に、Socket.io を使用してアプリに接続するページをセットアップしましたが、そのソリューションは、クライアント側のページがノード サーバーでホストされている場合にのみ機能するようです。たとえば、サードパーティのサイトでは次のようになります。

http://node.appserver.com:8080/tracker.js

そのスクリプトはサイトからデータを収集し、socket.io 経由でアプリに接続しますが、アプリがアプリ自体ではなく index.html ファイルからの要求をリッスンしていたため、応答を返すことができなかったようです。 tracker.js スクリプトから。

アプリを実行したいフローは次のとおりです。

http://www.evernote.com/shard/s7/sh/56f88de2-f1c0-470b-9169-c7aca1479037/92b00f81ff86eebd4add6f6f68053a50

tracker.js は次を使用して接続します。

$.getScript('/socket.io/socket.io.js', function(data){
  var socket = io.connect('http://node.appserver.com:8080');
  socket.emit('adTracker', 
    { adServer: 'datalunk', zone : 'top_home', referingURL : 'comple.com' } 
  );
});

次に、アプリは次のようになります。

var app = require('http').createServer(handler)
  , io = require('socket.io').listen(app)
  , fs = require('fs')

app.listen(8080);

io.configure(function () {
    io.set('authorization', function (handshakeData, callback) {
        if (handshakeData.xdomain) {
            callback('Cross-domain connections are not allowed');
        } else {
        callback(null, true);
        }
    });
});


function handler (req, res) {
  fs.readFile(__dirname + '/index.html',
  function (err, data) {
    if (err) {
      res.writeHead(500);
      return res.end('Error loading index.html');
    }

    res.writeHead(200);
    res.end(data);
  });
}

io.sockets.on('connection', function (socket) {
  socket.on('adTracker', function (data) {
var adRequestData = data;
var pass = ["bigbooks"];
var databaseUrl = "username:password@linus.mongohq.com:10006/node-test";
var collections = ["cmnads"]
var db = require("mongojs").connect(databaseUrl, collections);

db.cmnads.insert({adRequest : adRequestData}, {$set: {password: pass}}, function(err, updated) {
    if( err || !updated ) console.log("User not updated");
    else console.log("User updated");
    });
  });
});

ネットワークサイトを実際のノードアプリに接続する方法について、誰かが私に洞察を与えることができますか?

4

1 に答える 1

6

サードパーティのクライアント サイトに tracker.js を含める必要があります (また、$.getScript のために socket.io + jQuery を含める必要があります)。

別の解決策は、tracker.js ( http://cdn.socket.io/stable/socket.io.jsである必要があります) の CDN から socket.io をロードし、jQuery 依存関係を削除することです。コードは次のようになります。このように(socket.ioをロードし、ロードされたときに自分のことをします):

(function(document, onload){

  var io = document.createElement('script');
  io.src = "//cdn.socket.io/stable/socket.io.js";
  io.setAttribute('async', 'true');
  if ( typeof onload === 'function') {
    io.onloadDone = false;
    io.onload = function() {
        io.onloadDone = true;
        onload();
    };
    io.onreadystatechange = function() {
        if ( "loaded" === io.readyState && !io.onloadDone ) {
            io.onloadDone = true;
            io.onload();
        }
    };
  }
  // head exists -> append to head, otherwise to body
  (document.getElementsByTagName('head') || document.getElementsByTagName('body'))[0].appendChild(io);

})(document, function(){
  // here socket.io should be ready
  var socket = io.connect('http://node.appserver.com:8080');
  // ...
});

これを tracker.js 内に配置し、どこかにホストすると、クライアントは tracker.js を含めることができます。

<script src="yourhost/tracker.js"></script>

しかし、通常、追跡システムはsocket.ioを使用して構築されていません(socket.ioは約100k圧縮されており、追跡ソリューションの場合はかなり大きいと思います)

通常、追跡システムは、リクエストを作成し、変数をパラメーターとして送信することによって行われます。

クライアントで:

var img = new Image();
img.src = "http://node.appserver.com:8080/tracking.gif?param1=value1&param2=value2";

サーバー上 (gif 1x1 px をホストし、tracking.gif という名前を付けます):

var http = require("http");
var url = require("url");
var trackingGif = fs.readFileSync("./tracking.gif");
http.Server(function (req, res) {
  var params = url.parse(req.url, true)).query;
  res.writeHead(200);
  res.end(trackingGif, "binary");
});

それが少し役立つことを願っています。ヒント: 私のコードはすべてテストされていませんが、意味が明確になるはずです。

于 2013-01-02T18:08:47.703 に答える