0

我正在尝试为DokuWiki开发一个插件,该插件将使 wiki 页面的实时协作编辑成为可能。我正在使用Node.jsShareJS这样做,但我遇到了一些麻烦,因为这是我第一次使用它们......

到目前为止我得到的是基于这个这个页面。

ShareJS 服务器 - http://localhost:3000

var express = require('express');
var app = express();

app.use(function(req, res, next) {
    res.header('Access-Control-Allow-Origin', 'http://localhost:3000');
    res.header('Access-Control-Allow-Methods', 'GET, OPTIONS');
    res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization');
    res.header('Access-Control-Allow-Credentials', true);
    return next();
});

// public folder to store assets
app.use(express.static(__dirname + '/public'));

// get sharejs dependencies
var sharejs = require('share');
require('redis');

// options for sharejs 
var options = {
    db: {type: 'redis'},
    browserChannel: { cors: "http://localhost/dokuwiki/" },
};

// attach the express server to sharejs
sharejs.server.attach(app, options);

// listen on port 3000 (for localhost) or the port defined for heroku
var port = process.env.PORT || 3000;
app.listen(port);

顺便说一句,当我运行它时会输出此警告:

在此处输入图像描述

多库维基

例如,在编辑 wiki 页面时,http://localhost/dokuwiki/doku.php?id=start&do=edit插件包含以下脚本:

然后执行这个:

window.onload = function() {

    // get dokuwiki editor textarea element
    var pad = document.getElementById('wiki__text');

    if (pad) { // if a wiki page is being edited
        // Server options
        var options = {
            origin: "http://localhost:3000/channel"
        };

        // Connect to the server
        var connection = sharejs.open('test', 'text', options, function(error, doc) {
            doc.attach_textarea(pad);
        });
    }

};

这导致 DokuWiki 页面编辑器出现以下错误:

在此处输入图像描述

我错过了什么?提前致谢!

4

1 回答 1

0

设法解决它!:) DeprecationWarning仍然存在,我不知道为什么,但它现在正在工作。

只需要编辑ShareJS 服务器代码:

  • browserChannel: { cors: "http://localhost/dokuwiki/" },从 ShareJS 选项中删除了该行

  • 使用Access-Control-Allow-Origin 中间件进行调整

这是“最终”的ShareJS 服务器代码:

var express = require('express');
var app = express();
var port = 3000;

app.use(function (req, res, next) {
    res.setHeader('Access-Control-Allow-Origin', '*');
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');
    res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With, content-type');
    res.setHeader('Access-Control-Allow-Credentials', true);
    next();
});

// public folder to store assets
app.use(express.static(__dirname + '/public'));

// get sharejs dependencies
var sharejs = require('share');
require('redis');

// options for sharejs 
var options = {
    db: {type: 'redis'},
};

// attach the express server to sharejs
sharejs.server.attach(app, options);

app.listen(port, function() {
    console.log('listening on *:' + port);
});

就是这样!现在我只需要再编辑一下这段代码,让不同的 wiki 页面有不同的 ShareJS 文本区域。

于 2016-09-12T22:11:40.183 回答