如何在网页上添加在线聊天窗口

html-css021

如何在网页上添加在线聊天窗口,第1张

1、实现用一个 (类索引数组 )来存储 socket 资源和对应的用户信息的方法代码。

2、实现创建服务器 socket 的方法代码如下。

3、实现服务器的主要逻辑方法代码。

4、实现服务器与客户端的交互定义 json 类型的消息格式的方法代码。

5、创建客户端方法:使用js实现事件机制来处理浏览器与服务器的交互的方法代码。

6、使用消息框 textarea 添加了一个键盘监控事件,当用户按下回车键时直接发送消息的方法代码。

两者不是一个系统,难免会有偏差。

两者的代码也不一样,html只是浅浅效仿,如果说偏差很大,那可能是代码敲错了,建议及时更改。微信支持多种语言,以及手机数据网络。用户可拍摄照片或视频发送至“朋友圈”。用户可在联系人列表中选择联系人,使用云端服务将数据备份和恢复,以保护用户通讯录数据。微信中还有订阅号、服务号、企业号等功能,可以供用户订阅他们喜欢的公众号,也提供一个良好的自媒体平台,每个人都可以申请个人订阅号发布个人的文章等,用户可以透过订阅或者搜索获取微信公众号的文章,用户使用微信大部分功能都不会被收取费用。

如何在浏览器中打开IM并执行相应操作?下面以旺旺为例说明,对于QQ等原理一致。

1. 浏览器中如何判断旺旺是否已经安装,

过程如下:

(1) 打开淘宝任意店铺页面,查看源码,在亮灯旺旺图标处有如下代码:

[html] view plain copy <a href="http://amos.alicdn.com/getcid.aw?v=3&uid=%B5%D1%C9%AF%C6%EC%BD%A2%B5%EA&site=cntaobao&groupid=416517&s=1&charset=gbk" target="_blank">   <span style="white-space:pre">  </span><img border="0" alt="给我发消息" src="http://amos.alicdn.com/grponline.aw?v=3&uid=%B5%D1%C9%AF%C6%EC%BD%A2%B5%EA&site=cntaobao&gids=416517&s=1">   </a>  

img是旺旺图标,重点是href的内容。查看href链接的源码,如下:

[html] view plain copy <html xmlns="http://www.w3.org/1999/xhtml">   <head><title></title> </head>    <body>    <script src="http://www.im.alisoft.com/webim/js/website.js" > </script>    <script language="javascript">       function windowClose(){            window.opener = null              window.open('','_top')            window.top.close()       }       sendClientMsg('', '', 'cntaobao', '笛莎旗舰店:25', 1, '')       setTimeout('windowClose()', 1)   </script>   </body> </html>  

从源码可知这段代码做了这几件事:首先调用sendClientMsg函数,等待1秒钟,打开一个空白窗口,然后关闭之。核心是sendClientMsg函数。它位于website.js中。查看website.js的源码。改源码被混淆压缩了,为了便于查看,找个在线js格式化工具将代码重新格式化一下。这里使用了“站长工具”提供的在线js格式化工具

有这样一段函数,它首先创建一个aliimx的activeX对象,如果创建成功则说明旺旺被安装了,否则根据站点来源(淘宝中国站、阿里中国站、雅虎中国站)分别判断是否安装了其它几个版本的旺旺。源码如下:

[javascript] view plain copy function isInstalledClient(C) {       try {           var B = new ActiveXObject("aliimx.wangwangx")           if (B != null) {               return 1           }       } catch(D) {}       var A = getSite(C)       if (A == "cntaobao") {           if (newCheckWangWangInstalled() != DEFAULT_VERSION) {               return 1           }       } else {           if (A == "cnalichn") {               if (newCheckAlitalkInstalled() != DEFAULT_VERSION) {                   return 1               }           } else {               if (A == "chnyahoo") {                   if (newCheckYahooInstalled() != DEFAULT_VERSION) {                       return 1                   }               } else {                   return 0               }           }       }       return 0   }   [javascript] view plain copy function newCheckAlitalkInstalled() {       var A = DEFAULT_VERSION       try {           var C = new ActiveXObject("AlitalkSetup.Install")           if (C != null) {               A = "cnalichn"           }       } catch(B) {}       return A   }   function newCheckWangWangInstalled() {       var A = DEFAULT_VERSION       try {           var C = new ActiveXObject("WangWangX.WangWangObj")           if (C != null && "1.6.06.0525" != C.GetVersionStr()) {               A = "cntaobao"           }       } catch(B) {} finally {           C = null       }       return A   }   function newCheckYahooInstalled() {       var A = DEFAULT_VERSION       try {           var C = new ActiveXObject("YahooWangWangX.WangWangObj")           if (C != null) {               A = "chnyahoo"           }       } catch(B) {}       return A   }  

为何通过

[javascript] view plain copy var B = new ActiveXObject("aliimx.wangwangx")   if (B != null) {       return 1   }  

这段代码能判断出Windows是否安装了旺旺呢?旺旺安装到Windows中之后会在注册表中写入若干条注册表项,在浏览器中通过ActiveX控件来读取注册表,如果能够找到相应的注册表项,则说明当前Windows中安装了旺旺,否则表明没有安装。调用

[javascript] view plain copynew ActiveXObject("aliimx.wangwangx")  

的时候浏览器会去读取注册表,在HKEY_CLASSES_ROOT下搜索aliimx.wangwangx表项,找到了则说明系统安装了阿里旺旺。

由此也可以知道,如果系统中的旺旺是未经“美化”的绿色版,浏览器不一定能够判断出它的存在。