使用Strophe库进行XMPP文件传输

时间:2011-09-05 05:10:37

标签: jquery xmpp strophe

任何人都可以通过strophe让我知道XMPP中文件传输的实现     文库

3 个答案:

答案 0 :(得分:1)

我建议您使用自己需要的XEP-0065: SOCKS5 Bytestreams编码,恐怕......

答案 1 :(得分:1)

这是一个可用的si-filetransfer插件。 您将不得不研究代码并添加处理程序:

connection.si_filetransfer.(addhandler);

然后将其用于:

   connection.si_filetransfer.send(to, sid, filename, size, mime, cb);

我之前尝试过,但由于某种原因导致我的连接失败,但未成功。也许你有更好的运气=)

答案 2 :(得分:1)

您可以使用si-filetransfer,我曾用它来发送文件,但它似乎没有我想要的那么快。它以绑定方式发送文件数据,因此速度会有些慢,也许应该考虑使用SOCKET5字节流(绑定),但是我之前没有尝试过。

发送文件演示,send()方法的参数几乎没有什么不同,因为我将其更改为适合我的应用程序,但基本相同。这样的框架

    // get Strohe.Connection
    getStropheConnection().si_filetransfer.send(file.id, 
        fullJid, sid, file.filename, file.size, filetype, function(err) {

        if(err) {
            // err happen
            return;
        } 

        // when codes comes here,mean your peer agree to receive your file
        // and we will use open to tell your peer you are going to send file
        // open: function (to, sid, bs, cb) 
        getStropheConnection().ibb.open(fullJid, sid, '4096', function(err) {

            if(err) {
                // err happen with open 
                return;
            }

            // code comes here, you can send data
            // call data method to send every peach of your file data
            // data: function (to, sid, seq, data, cb) 

            file.seq = 0; // the file sequence
            getStropheConnection().ibb.data(fullJid, sid, file.seq, d0, function(err) {

                if(err) {
                    // err happen  with data
                    return;
                }

                // repeat sending data util finish
                // call close tell your peer the file sending is finish
                // close: function (to, sid, cb) 
                getStropheConnection().ibb.close(fullJid, sid, function(err) {
                    if(err) {
                        // err happen with close
                        return;
                    }
                }.bind(this));
            }.bind(this));
        }.bind(this));
    }.bind(this));

并接收

_ibbReceiveFileCb : function(type, from, sid, data, seq, blocksize) {


    switch(type) {
        case "open":


          break;
        case "data":


          break;
        case "close":
            // every data through base64 encode, and 3 byte turn to 4 byte
            // compare receive size and file size make sure receive all data
            var resize = Math.ceil(file.blocksize * (file.seq + 1) / 4) * 3;
            var size = file.size; 
            if(resize >= size) {
                // receive all data
            } else {
                // not receive all data
            }
            break;
        default:
          throw new Error("shouldn't be here.");
      }
},

抱歉,无法提供完整的代码,因为它包含其他代码,例如用于保存数据的JSON对象,这可能会使您感到困惑。只是简单的框架就足够了