工作需要仔细看了一下JWChar的源码
我对JavaScript并不熟悉,有分析和理解错误的地方,请朋友指教
首先是关于JWChat,一个用AJAX和html来实现的jabber客户端(我用jabber服务器实现是openfire),作为采用web形式开发的客户端,摒弃了C/S结构客户端的繁琐和使用上的不便。
JavaScript是客户端的核心技术。
慢慢逐一的介绍框架中js文件中每个方法的作用
-
config.js配置文件(TODO)
- jsjac.js核心文件(是不是可以理解为J
ava S
cript Ja
bber C
ore)
- 但不管怎么理解,它是客户端中最重要的部分。它的作用包括了处理和拼接xml信息
- 定义并初始化一些变量(配置)
(todo)
- Shared.js 可以共享的一些工具类,代码不多
function getArgs()获取url中的参数
function cutResource(aJID)从一个已给的jid中去掉resource部分
function makeWindowName(wName)替换一些特殊符号成英文单词
function htmlEnc(str)过滤html代码中的特殊符号有"&<>\"四个
function msgFormat(msg)信息格式化,替换信息中的表情和urls
function isValidJID(jid)验证jid的节点名是否包含如下非法的字符'"',' ','&','\'','/',':','<','>','@'
function jab2date(ts)转换jabber返回来的时间戳成js日期对象
function hrTime(ts)转换2004-08-13T12:07:04±02:00返回来的时间格式到一个人类可以阅读理解的格式
function jabberDate(date)将js对象类型的时间转换为jabber的时间格式
- browsercheck.js浏览器检查
function BrowserCheck()只有一个方法用来检查浏览器生产商和特定版本,在方法外自动生成了一个名为is的BrowserCheck对象。
- emoticons.js写明了表情的特殊符号与图片的对应关系,作用就是在做message内容过滤的时候将代表表情信息的特殊符号,转换为相应图片名称。
- jabber_x_data.js只有两个方法
function genJabberXDataReply(form)
function genJabberXDataTable(x)根据传过来的对象x进行一些html代码的生成
- pngfix.js
从命名规则可以看得出,是为了有关png图片方面缺陷上的处理
function correctPNG()正确的处理PNG图片在IE5.5或者更高版本中的透明度问题
当中有onload=correctPNG(),也就是说在加载的时候就会自动执行
其中有段代码的大小写大概是对进行一个替换,比如将onclick替换成onClick
- roster.js从名字上看大概就是名单和组群方面功能的实现
代码相对上面几个较多,(todo),todo了
- sounds.js或许和声音有关吧(todo)
- statusLed.js状态(todo)
- switchStyle.js(转换类型,是转换在线状态吗?)
- version.js版本,偷偷看了一下,内容很简单,就一句
var VERSION="1.0beta3";
大概也就这些js文件。真要是从头看到尾,头还真疼。
第一步,我只是想它是怎么和jabber服务器(openfire)交互的,并且很好奇与服务器交互的核心代码在哪个js文件里)。在我看来,理解了这些,你又知道了在jsjac.js做了一些message发布和接受的处理(也就是对xml拼合和解析的过程),只要知道了如何和服务器交互,我想自己也可以实现一个简单的IM软件。因为openfire底层应用的是XMPP协议嘛,信息格式正确,问题就不大。
(todo)(这里忽略了一个问题,jwchat是一个web应用,它有它自己的web.xml配置,当中应用了servlet来接受请求再转发给jabber。
N分钟后
发现一个问题。在1.0版本的源码中包含api文档。似乎开发包有些不规范,为什么1.0b3版本里没有。
分享到:
相关推荐
前端聊天工具jwChat的源码分析与学习 在现代Web应用中,实时通信功能变得越来越重要,尤其在社交、协作和客户服务场景下。jwChat是一款专为前端设计的聊天软件,它的源码为我们提供了一个深入了解前端实时通信实现...
JWChat源码 1、首先配置jwchat要具备的环境(我开发的环境) tomcat7.0 jdk1.7 openfire3.9.3 2.在网上查找下在jwchat.war文件,将其解压后放到tomcat目录下的webapps下 3.下载xalan的xalan.jar,serializer.jar, ...
JwChat极简聊天框组件是一款基于Vue和ElementUI极简的聊天框组件。 软件包含了表情包功能,可自动匹配微信表情。还包含了聊天窗口配置组件,可以自由配置顶部状态栏和右侧信息栏。 JwChat安装: 使用 npm 安装 npm ...
《JWCHAT源码解析:构建基于JavaScript的Openfire Web聊天工具》 JWCHAT是一款基于JavaScript开发的开源Web聊天工具,它与Openfire服务器配合使用,为用户提供实时、交互式的在线聊天体验。通过深入理解JWCHAT的...
jwchat汉化源码,基于openfire服务器端的,可以跑得通,直接将war格式文件导入到eclipse中即可。然后就可以应用了,注意jdk版本至少要1.5以上。
下载jwchat源码后,将其部署到Apache服务器的Web根目录下。 1. 解压缩jwchat文件,确保所有文件都在同一目录下。 2. 修改config.js配置文件,将服务器地址、端口、域名以及openfire的服务器地址和端口填入相应位置。...
jwchat.war jwchat.war jwchat.war jwchat.war
- 获取Jwchat的源码或者预编译的包,确保与Openfire版本兼容。 - 修改Jwchat的配置文件,配置Openfire服务器地址、端口、服务器域名以及API密钥等信息。 - 如果需要,可以对Jwchat的主题、语言、权限等进行个性化...
3. **JWChat源码编译**: 获取JWChat的源代码后,使用标准的C/C++编译器进行编译。可能需要调整编译选项以适应你的环境,例如指定路径链接到XMPP服务器的库。 4. **配置文件修改**: JWChat的配置文件(通常是`config...
源码源代码是开发人员进行二次开发的基础,JwChat的源代码提供了完全透明的实现细节,开发者可以根据需求对其进行定制和扩展。源代码的开放性使得用户能够深入理解其工作原理,解决在实际应用中遇到的问题,或者根据...
标题"jwchat修改过全部中文可以直接用"表明这是一款名为jwchat的软件,经过了全面的汉化处理,用户下载后无需额外设置即可直接使用中文版。 描述中的"自己在下个openfire服务器,直接可以用"意味着jwchat可能与...
3. **安全性**:作为开源软件,jwchat的代码公开透明,允许开发者对源码进行审查,确保了软件的安全性和隐私保护。此外,它可能还支持SSL加密,增强了数据传输的安全性。 4. **易用性**:jwchat的界面设计简洁直观...
- **构建流程**:通过编译源码,将结果打包成WAR文件,其中包含了`WEB-INF`目录下的所有资源。 - **部署**:将WAR文件部署到支持Java Servlet容器(如Tomcat、Jetty等)上,容器会自动解析`WEB-INF/web.xml`并启动...
JwChat极简聊天框组件 v1.1.0 是一款专为开发者设计的轻量级聊天界面解决方案,旨在提供快速集成、高度自定义以及流畅用户体验的聊天功能。这款组件适用于网页应用,可以帮助开发者轻松地在他们的项目中构建出美观且...
3. **可扩展性**:Openfire允许开发者通过插件进行功能扩展,如集成其他服务、日志记录、统计分析等。 4. **多语言支持**:Openfire支持多种语言,便于全球用户使用。 5. **管理员工具**:强大的管理控制台让管理...
《JWChat 1.0:打造实时通讯的Web客户端》 JWChat 1.0 是一个专为实现即时通讯功能而设计的Web客户端,它允许用户在浏览器上进行实时的消息交换,无需安装额外的桌面应用。这个开源项目不仅提高了沟通的便捷性,...
【标题】"可运行的jwchat程序包"是一个整合了多个组件的软件包,旨在提供一个便捷的方式来运行jwchat聊天应用。这个程序包包含了jwchat本身,以及两个重要的依赖库——xalan和JabberHTTPBind。xalan是Apache组织开发...
我们下载安装的是httpd-2.2.17-win32-x86-no_ssl.msi,安装完成后,我们需要配置一下,由于jwchat是用javacript去和openfire进行通讯的,所以他们之间的通讯是基于http的,但是由于浏览器为了安全性是不允许...