0

環境

  • エクスプレス 3.2.4
  • ShareJS 0.6.2
  • OS X 10.8.3

ゴール

Express アプリ内で ShareJS を実行しようとしています。


問題

node app.js実行時に次のエラーが表示されます。

/Users/eric/Documents/Projects/collabit/node_modules/share/src/server/index.coffee:52
      server.use(options.staticpath, connect["static"]("" + __dirname + "/../.
             ^
TypeError: Object #<Server> has no method 'use'
    at Function.create.attach.attach (/Users/eric/Documents/Projects/collabit/node_modules/share/src/server/index.coffee:52:14)
    at Object.<anonymous> (/Users/eric/Documents/Projects/collabit/app.js:43:16)
    at Module._compile (module.js:449:26)
    at Object.Module._extensions..js (module.js:467:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Module.runMain (module.js:492:10)
    at process.startup.processNextTick.process._tickCallback (node.js:244:9)

私はエクスプレス cli インターフェイスを使用してアプリを生成し、ShareJS でスワップすることを決定する前に SocketIO で問題なく作業していました。私の問題はサーバーの作成方法にあると確信していますが、高速機能を維持するためにサーバーオブジェクトを作成する方法を理解するのに十分ではありません、ShareJSがアタッチできるようにします.b


コード

/**
 * Module dependencies.
 */

var express = require('express')
  , sharejs = require('share')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path');

var app = express();

app.configure(function(){
  app.set('port', process.env.PORT || 3000);
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jade');
  app.use(express.favicon());
  app.use(express.logger('dev'));
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(app.router);
  app.use(express.static(path.join(__dirname, 'public')));
});

app.configure('development', function(){
  app.use(express.errorHandler());
});

app.get('/', routes.index);
app.get('/users', user.list);

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

/**
 * ShareJS Code
 */

var options = {db: {type: 'none'}};
sharejs.server.attach(server, options);

質問

Express 機能を維持しながら ShareJS をサーバー オブジェクトにアタッチできるようにするために、サーバー オブジェクトを作成する適切な方法は何ですか。


ありがとう!

ご協力ありがとうございます。追加情報が必要な場合はお知らせください。

4

1 に答える 1

3

同様の問題がありました。多くの試行錯誤の後、これは私にとってはうまくいきました:

var express = require('express'),
http = require('http'),
sharejs = require('share').server;

var app  = express();
var server = http.createServer(app); 

var options = {db:{type:'none'}}; // See docs for options. {type: 'redis'} to enable     persistance.

// Attach the sharejs REST and Socket.io interfaces to the server
sharejs.attach(app, options);

app.use(app.router);

app.set('views', __dirname + '/views');
app.engine('html', require('ejs').renderFile);

server.listen(8000, function () {
    console.log('Server running at http://127.0.0.1:8000/');
});

app.get('/', function(req, res) {
    res.render('share.html');
});

次に、views/share.html に標準的な HTML の例を示します。

<!DOCTYPE html>
<html>
<head>
    <title>Test</title>
    <script src="http://ajaxorg.github.com/ace/build/src/ace.js"></script>
    <script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
    <script src="/channel/bcsocket.js"></script>
    <script src="/share/share.js"></script>
    <script src="/share/ace.js"></script>
    <script>
        $(document).ready(function() {
            var editor = ace.edit("editor");

            sharejs.open('hello', 'text', 'http://localhost:8000/channel', function (error, doc) {
                doc.attach_ace(editor);
            });
        });
    </script>
    <style>
        #editor {
            width: 200px;
            height: 100px;
        }
    </style>
</head>
    <body>
        <div id="editor"></div>
    </body>
</html>
于 2013-06-14T07:52:46.933 に答える