JWChat源码研究心得

最近研究JWChat这个基于jabber协议的聊天工具,搞了几个星期了,有点了解的地方在这里记录一下,先要说一声感谢本网站的:mircle 一篇文章:<a href="http://www.iteye.com/topic/154697" target="_balnk">http://www.iteye.com/topic/154697</a>,写的非常详细.入门配置是没有什么问题了。下面是我最近看代码的一点平时记录:
JWChat的jabber连接是面向对象的继承操作,核心类全部在jsjac.js里面,后面我看了,这个是一个独立的基于javascript 连接jabber服务器的组件,JWChat只是应用了他。
jwchat.html的init()方法里面有二种连接方法,分别是:JSJaCHttpBindingConnection和JSJaCHttpPollingConnection,这二种都继承了JSJaCConnection,JSJaCConnection是和jabber服务器连接的类, JSJaCHttpBindingConnection中 connect 是JSJaCHBCConnect. JSJaCCHBCConnect是把客户端的各种信息组合成jabber协议的xml请求文档,它的oCon就是 JSJaCConnection的实例,


JSJaCConnection里面的 JSJaCHBCDisconnect

在jwchat项目中,chat.html是发送信息的页面,function submitClicked是发送按钮的事件,这里的aMessage是发送信息对象,其中jwcMain就是chat.html的上级页面:jwchat.html对象。
var aMessage = new JSJaCMessage();
aMessage.setType('chat');
aMessage.setTo(user.jid);
aMessage.setBody(body);

jwcMain.con.send(aMessage);

jsjac.js里面, JSJaCConnection.prototype._sendRaw 发送信息的方法。


jsjac 里面的 JSJaCConnection.prototype._handleEven 是触发事件的方法。


shared.js 是JWChat项目中,js共用方法类,里面有许多共用的方法让其它function 调用 : for example:cutResource
roster.js 是针对聊天好友和信息的管理js 文件。
roster.js里面的 RosterOpenChat,是打开聊天窗口 chat.html页面,并且加载收到的信息

JWChat 信息发送过程研究总结:ClientA 发送信息给 ClientB,先发送给 JHBServlet,然后JHBservlet发送给 openfire jabber服务器,openfire jabber服务器分析接收信息,查找接收信息ClientB,通过ClientB和服务器建立的xml流直接把信息发送给ClientB.

JWChat 里面请求加为好友的代码:subscription.thml 15行:
function sendSub() {
var aPresence = new JSJaCPresence();
aPresence.setType('subscribe');

if (!document.forms[0].to.value || document.forms[0].to.value == '') {
alert("JID missing");
document.forms[0].to.focus();
return false;
}

var to = document.forms[0].to.value;
if (to.indexOf('@') == -1)
to += '@' + srcW.JABBERSERVER;

aPresence.setTo(to);
if (document.forms[0].msg.value && document.forms[0].msg.value != '')
aPresence.setStatus(document.forms[0].msg.value);
alert(aPresence.getDoc().xml);
srcW.con.send(aPresence);

window.close();
}


JWchat里面的 function handlePresence 是接收和发送用户增加好友请求处理的函数

未完,待续
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JWChat源码 1、首先配置jwchat要具备的环境(我开发的环境) tomcat7.0 jdk1.7 openfire3.9.3 2.在网上查找下在jwchat.war文件,将其解压后放到tomcat目录下的webapps下 3.下载xalan的xalan.jar,serializer.jar, xercesImpl.jar, xml-apis.jar放到webapps\jwchat\WEB-INF\lib目录下即可。 4.修改配置文件 config.js 复制代码 1 var SITENAME = "127.0.0.1";//127.0.0.1是你openfire服务器的名称 2 var BACKENDS = 3 [ 4 { 5 name:"Open Relay", 6 description:"HTTP Binding backend that allows connecting to any jabber server", 7 httpbase:"/jwchat/JHB/", 8 type:"binding", 9 default_server: SITENAME 10 } 11 ]; 复制代码 jsjac.js 在302行if(this.has_sasl)前加this.has_sasl=false; web.xml 1 <servlet-mapping> 2 <servlet-name>Jabber HTTP Binding Servlet</servlet-name> 3 <url-pattern>/JHB/</url-pattern> <!--这里的修改主页是对应上面的config.js,如果config.js的httpbase配置是/jwchat/,那这里的就不用修改了 --> 4 </servlet-mapping> (黄色表示要修改的部分) 5.启动tomcat ,访问http://l127.0.0.1:8080/jwchat/ (切记如果你的openfire服务器名称为127.0.0.1,访问jwchat时浏览器输入127.0.0.1,如果输入localhost则会报Authorization failed),我就是因为这个问题烦恼了很长一段时间。 <报错修改> 1.如果报Service unavailable A.可能是openfire没有启动 B.config.js中的var SITENAME = "127.0.0.1";没有与openfire服务器名称相同   2修改openfire服务器名称 A.点击服务器,服务器管理器,编辑属性 修改服务器名称,修改完的服务器名称前有感叹号 B.出现叹号,我们要删除安全证书,点击服务器,服务器设置,服务器证书删掉这里的证书。 C.删除后,在当前页面会出现提示,然后按照提示点击相应的链接,重启服务器,然后登陆,再生成证书 D.然后生成完成后,手动重启openfire服务器,再次登陆发现警告没有了。 3. 在服务器端增加配置 xmpp.httpbind.client.requests.polling = 0 xmpp.httpbind.client.requests.wait = 10
一、apache服务器配置。 我们下载安装的是httpd-2.2.17-win32-x86-no_ssl.msi,安装完成后,我们需要配置一下,由于jwchat是用javacript去和openfire进行通讯的,所以他们之间的通讯是基于http的,但是由于浏览器为了安全性是不允许javascript跨域访问的。我们必须通过别的技术来绕过这限制,所以我们采取apache服务器的重定向功能去突破这个限制。 安装完成后进入到apache的安装目找到conf文件夹下的httpd.conf文件,用记事本打开,把下列几个配置项放开(默认被注释掉了) 1、LoadModule rewrite_module modules/mod_rewrite.so 2、LoadModule proxy_module modules/mod_proxy.so 3、LoadModule proxy_http_module modules/mod_proxy_http.so 然后再在本配置文件的末尾加入如下几行配置 ServerName blzc.com <Directory /var/jwchat> Options +Indexes +MultiViews </Directory> AddDefaultCharset UTF-8 RewriteEngine on ProxyPass /jwchat/http-bind/ http://blzc.com:7070/http-bind/ 在此有必要对proxyPass的参数做些说明 “/jwchat/http-bind/”:jwchat就通过访问http://域名/jwchat/http-bind/地址去和openfire通讯,apache接到请求后就会重新定向到http://blzc.com:7070/http-bind/ “http://blzc.com:7070/http-bind/”:被重新定向的地址,也就是我们的openfire的http访问地址。7070端口是openfire的默认访问端口,当然我们也可以进入openfire进行配置。 二、openfire的配置 安装好openfire后进入web式的管理界面,选择服务器-》服务器管理器-》系统属性 在里边添加两个属性 xmpp.httpbind.client.requests.polling = 0 xmpp.httpbind.client.requests.wait = 10 三、部署jwchat jwchat解压后的文件内容放到apache访问目录/jwchat文件夹下, 然后打开config.js文件,把相应的内容修改为如下的形式 var SITENAME = "blzc.com";//你要访问openfir的域名 name:"Native Binding", description:"Ejabberd's native HTTP Binding backend", httpbase:"/jwchat/http-bind/",//访问openfire的地址 type:"binding", servers_allowed:[SITENAME] 最后再把jwchat文件夹考到apache的htdocs文件夹下,重新启动服务,然后访问http://localhost/jwchat即可。 若出现“authorization failed”,则可能是SSL不支持的原因,需要修改jsjac.js,在if(this.has_sasl) 前面加上this.has_sasl=false;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值