资讯专栏INFORMATION COLUMN

即时通讯之客户端篇StropheJs.

ChristmasBoy / 1496人阅读

摘要:解析的最终结果是,上下线通知。解析的结果是,同时可以通过和构建父子级别元素。单聊发送查询归档历史记录漫游查询归档之前,首先是要确保归档存库成功,服务端查看传送门,自行处理,参见。栽过的坑转的时候回调函数丢失参考文献高级编程使用和

摘要

小编是个写了几年php的码农, 接触纯Js的项目这也是头一次,另外,IM的服务端是Java(tigase框架) ,为了解决旧版本BOSH(长轮询)即时消息不稳定问题,决定更换pc网页版为websockt链接, App用socket直连,特此更新服务端到8.0,更新安装期间遇到了不少坑,再次记录,熟练IM或者xmpp协议用法的不用继续看了。

怎么添加账户,测试是否成功等工具方法见另一篇

传送门
基础语法

xmpp寻址和节,另一篇基础 应用层协议之xmpp基础学习
xmpp主要是以xml格式传输数据,详细请看xep协议,这里用strophe的构建器,主要用到的如下:

$iq,info query,主要用来查询服务器信息,解析的最终结果是。
$pres,解析的最终结果是,上下线通知。
$msg, 解析的结果是,同时可以通过.up()和.c()构建xml父子级别元素。
执行流程 登陆认证
im.connect = new Strophe.Connection("ws://localhost:5290/xmpp-websocket/");
im.connect.connect("jid@localhost","pass",function(){
    console.info("this is login callback.");
});

这里,服务端其实是分为两步走,第一步是连接,连接成功后会返回状态码1,然后是登陆,登陆成功后返回状态5,详细的状态码参考源码:

关于密码认证的问题,暂时采取plain方式,后续更新其他方式,比如:sha1。

单聊

发送demo

var msg = $msg({
            to: receiver,
            from: "jid@localhost",
            type: "one",
            name: "zeronlee",
            photo: "image.png"
        }).c("body", null,msg);
        im.connect.send(msg.tree());

查询归档(历史记录漫游)

查询归档之前,首先是要确保归档(存库)成功,服务端查看【传送门】,自行处理,参见XEP-0136: Message Archiving。

最简单的demo:

var iq = $iq({type: "set"}).c("query", {xmlns: "urn:xmpp:mam:1"});
    im.connect.sendIQ(iq, function(a){
        console.log("sent iq",a);

        $(a).find("item").each(function(){
            var jid = $(this).attr("jid"); // jid
            console.log("jid",jid);
        });
    });

成功后返回以下信息:




  nAhOrNd/DNXBFtivwbm/vrN8I4GL2SLkc76eNmN0ruw=
  cnosUN6U9Md6o8TvLD42rB6jJnfPKF2DxkEBFmuK/IQ=
  14


表明查出了14条历史消息,查询归档更多见XEP-0313: Message Archive Management,示例代码见《插件使用方法》。

群聊

群聊相对单聊要复杂的多,首先是入群(这里的群没有密码),出席,发消息。

出席

   var presence = $pres({from:"im7858@localhost",to:"6043@muc.localhost"}).c("x", {xmlns: "http://jabber.org/protocol/muc"}).c("history", {maxstanzas: 0, maxchars:0, seconds:0});
    im.connect.send(presence, function(a){
        console.log("sent presence",a);
   
    });

查询群开放功能信息

var presence = $iq({from:"im7858@localhost@muc.localhost"}).c("query", {xmlns: "http://jabber.org/protocol/disco#items"});
im.connect.send(presence, function(a){
    console.log("sent presence",a);

});

发消息同单聊

订阅推送 内网穿透 插件使用方法

mam归档查询demo

/* XEP-0313: Message Archive Management
 * Copyright (C) 2012 Kim Alvefur
 *
 * This file is MIT/X11 licensed. Please see the
 * LICENSE.txt file in the source package for more information.
 *
 * Modified by: Chris Tunbridge (github.com/Destreyf/)
 * Updated to support v0.3 of the XMPP XEP-0313 standard
 * http://xmpp.org/extensions/xep-0313.html
 *
 */

Strophe.addConnectionPlugin("mam", {
    _c: null,
    _p: [ "with", "start", "end" ],
    init: function (conn) {
        this._c = conn;
        Strophe.addNamespace("MAM", "urn:xmpp:mam:1");
    },
    query: function (jid, options) {
        var _p = this._p;
        var attr = {
            type:"set",
            from:jid
        };
        options = options || {};
        var mamAttr = {xmlns: Strophe.NS.MAM, with:jid};
        if (!!options.queryid) {
            mamAttr.queryid = options.queryid;
            delete options.queryid;
        }
        var iq = $iq(attr).c("query", mamAttr);

        // var i;
        // for (i = 0; i < this._p.length; i++) {
        //     var pn = _p[i];
        //     var p = options[pn];
        //     delete options[pn];
        //     if (!!p) {
        //         iq.c("field",{var:pn}).c("value").t(p).up().up();
        //     }
        // }
        // iq.up();
        //
        var onMessage = options.onMessage;
        delete options.onMessage;
        var onComplete = options.onComplete;
        delete options.onComplete;
        ////////////////////////////////////////////////
        // iq.cnode(new Strophe.RSM(options).toXML());

        var _c = this._c;
        var handler = _c.addHandler(onMessage, null, "message", null);
        return this._c.sendIQ(iq, function (a) {
            console.log(a);
                _c.deleteHandler(handler);
                onComplete.apply(this, arguments);
            },
            function (err) {
                //error callBack function
                console.log("Error Response from server:", err);
            });
    }
});

插件必须是Strophe.addConnectionPlugin("mam", {init:function(){}})结构才得以成功加载,用webpack或者页面加载进来之后自动实例化init,群聊就是以插件形式使用,当然还可以自定义其他更高级的,具体参考《XMPP高级编程+使用JavaScript和jQuery》第三部分十四章。

栽过的坑

addHandlers转handlers的时候回调函数丢失.

参考文献

XMPP高级编程+使用JavaScript和jQuery

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/105596.html

相关文章

  • 即时通讯服务端Tigase.

    摘要:摘要是一个应用层协议,主要做网页版即时通讯,是基于和实现,服务端常见的框架有等,这三个都亲自踩过坑,唯有相对牛逼完善一些,客户端主要就是了。 摘要 xmpp是一个应用层协议,主要做网页版即时通讯,是基于RFC3920和RFC3921实现,服务端常见的框架有openfire,tigase,prosody等,这三个都亲自踩过坑,唯有tigase8.0相对牛逼(完善)一些,客户端主要就是st...

    msup 评论0 收藏0
  • 即时通讯云行业提速 网易云信何以登上科技

    摘要:网易云信即时通讯云服务的产品优势网易云信涉足多元行业提升用户体验满足内外协同今年月,网易云信正式宣布通信与视频业务实现战略升级。  韩寒导演的影片《乘风破浪》中,有这样一个片段,在六一还坚持囤BB机有前途的时候,从事电脑编程和软件开发的小马则认为即时通讯才是未来的发展方向。看到这里,很多观影者都不谋而合地笑了,小马口中的即时通讯就是在1999年诞生的OICQ。影片中阿浪说的那句话没错,这个世...

    mengera88 评论0 收藏0

发表评论

0条评论

ChristmasBoy

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<