qq78707 发表于 2015-8-27 09:28:05

PHP+ajax聊天室源码!支持长轮循跟定时请求两种

  

  
  




1 var lastID = "1";//声明上次取回的消息的ID
2 var isposted = false;
3 var mGetTime;//设置setTimeout的返回值
4 // 通过封装getAjax()方法创建XMLHTTPRequest对象
5function trim(str){ //删除左右两端的空格
6  return str.replace(/(^\s*)|(\s*$)/g, "");
7 }
8
9 function getPlainTxt() {
10 var str=UE.getEditor('myEditor').getContent()
11 str=trim(str);
12 $('#mess').html(str);
13 }
14
15 function setContentmess() {
16 UE.getEditor('myEditor').setContent('', false);
17 return;
18 }
19
20 //获取JSURL后面的参数
21 function _getArgs(name,_number){
22 var jsFileName = name;
23 var rName = new RegExp(jsFileName+"(\\?(.*))?$")
24 var jss=document.getElementsByTagName('script');
25 for (var i = 0;i < jss.length; i++){
26   var j = jss;
27   if (j.src&&j.src.match(rName)){
28   var oo = j.src.match(rName);
29   if (oo&&(t = oo.match(/([^&=]+)=([^=&]+)/g))){
30         for (var l = 0; l < t.length; l++){
31             r = t;
32             var tt = r.match(/([^&=]+)=([^=&]+)/);
33             if (tt)
34             return tt;
35               //document.write('参数:' + tt + ',参数值:' + tt + '<br />');
36         }
37   }
38   }
39 }
40 }
41
42
43 function user_to(){
44 var userid1=$('#userid1').val();
45   if(userid1=='所有人'){
46 alert('请选择聊天对象哦!\n\n点击用户名称即可!');
47 $("#userid2").attr("checked",false);
48   }
49 return false;
50 }
51
52
53
54
55
56 //点击选择用户
57 function getFirend(name) {
58   var new_name;
59   if(name.length > 1 && name!="所有人") {
60         $("#userto").val(name);
61         $("#userid1").attr("checked",false);
62         $("#userid2").attr("checked",true);
63
64         if(name.length > 8) {
65             new_name = name.substr(0, 6);
66         } else {
67             new_name = name;
68         }
69         document.getElementById("tousertitle").innerHTML = "<font color=#ff6600 title=" + new_name + ">" + new_name + "</font>";
70   }else{
71
72         $("#userto").val("所有人");
73
74         $("#userid1").attr("checked",true);
75         $("#userid2").attr("checked",false);
76
77
78
79         document.getElementById("tousertitle").innerHTML = "用户";
80   }
81 }
82
83
84
85 //发送消息的方法
86 function sendMess()
87 {
88
89    getPlainTxt();
90   //如果消息为空给出提示并返回
91   var messvalue=$("#mess").html();
92         messvalue=trim(messvalue);
93
94         if(messvalue.length>650){
95         alert("参与互动提示:\n亲,输入的文字是不是有点多了?!,少说点吧!\n\n复制过来的文字!请先清除格式!");
96         //document.getElementById("mess").focus();//把焦点设置到消息输入框
97         return false;
98         }
99
100
101
102         if($("#mess").html().length<2){
103         alert("参与互动提示:\n请填写您要发表的内容,长度必须2~250个字节!");
104         //document.getElementById("mess").focus();//把焦点设置到消息输入框
105         return false;
106         }
107
108   var d = new Date();
109         var username = $("#username").val() ;
110         var userto   = $("#userto").val() ;
111         var userid   = $("#userid").val() ;
112         //var mess   = document.getElementById("mess").value ;
113         var mess   = messvalue ;
114         var userpid= $("#userpid").val() ;
115         var IP       = $("#IP").val() ;
116         var usertype = $("#usertype").val() ;
117
118         var sendUrl = "username="+username+"&userto="+userto+"&userid="+userid+"&userpid="+userpid+"&mess="+mess +"&IP="+IP +"&usertype="+usertype+"&d="+d.getTime();
119         var sendUrl = encodeURI(sendUrl);
120       XMLHttp.sendReq('POST', 'send.php',sendUrl, send_response);
121
122
123 }
124
125 function send_response(obj){
126   var response = obj.responseText;
127   if(response=='ok'){
128 if(!isposted){
129 isposted = true;
130 getMess();
131 }
132       setContentmess();//设置消息框为空
133   }
134   if(response=='false'){
135       alert("发送失败!你的字符含有非法字");
136 getMess();
137   }
138 }
139
140 function getMess(){
141 var d = new Date();
142
143 var getUrl = "getmess.php?lastid="+lastID +"&numbermess=80&d="+d.getTime();//从服务器返回消息的地址
144$.ajax({
145               type:"GET",
146               dataType:"xml",
147               url:getUrl,
148               async: true,
149               timeout:80000,   //ajax请求超时时间80秒
150
151               success:function(data,textStatus){
152                     //从服务器得到数据,显示数据并继续查询
153 isposted = false;
154 var chatEL = $("#chat");
155 $(data).find("message").each(function(i,va){
156 varsid      =$(this).find("sid").text();
157 varsucc   =$(this).find("succ").text();
158 varumax   =$(this).find("umax").text();
159 varuser   =$(this).find("user").text();
160 varuserto   =$(this).find("userto").text();
161 varuserid   =$(this).find("userid").text();
162 varusersex=$(this).find("usersex").text();
163 varusertype =$(this).find("usertype").text();
164 varuserpic=$(this).find("userpic").text();
165 varuserpid=$(this).find("userpid").text();
166 vartext   =$(this).find("text").text();
167 vardate   =$(this).find("date").text();
168 varuid          = _getArgs('function.js','2')
169//有数据
170
171if(succ==1){
172               if(uid>=98){
173               delhtml='<a href="#"id="delmess" onclick=delmess("'+ sid +'","delmess");>[删除]</a><a href="#"onclick=delmess("'+ userid +'","delusermess");id="delusermess">[删除该用户的全部信息]</a>';
174               }else{
175               delhtml='';
176               }
177               if(usertype>=98){
178               var chatELinnerHTML = '<div class=chu><ul><li class=chu1><a href=http://www.0917cc.com?ID='+userid+' target=_blank><img src='+userpic+' border=0 width=70 height=70 /></a></li><li class=chu2><a href=http://www.0917cc.com?ID='+userid+' target=_blank><img src=/WebSystems/images/img/icons/gif/group.png /></a> <a href=javascript:void(0) onclick=getFirend("'+ user +'"); ><font class=ChatFont3>管理员(' + user + ')</font></a> <img src=/WebSystems/images/img/icons/gif/male.png /> <a href=javascript:void(0) onclick=getFirend("'+ userto +'");><font class=ChatFont3>' + userto + '</font></a> <font color=#575D69>说</font> <font color=#575D69>' + date +'</font><img src=/WebSystems/images/img/icons/gif/07.gif />'+delhtml+'<br>' +text + '</li></ul></div>';
179               chatEL.append(chatELinnerHTML);
180               }else{
181               var chatELinnerHTML = '<div class=chu><ul><li class=chu1><a href="#" target=_blank><img src='+userpic+' border=0 width=70 height=70 /></a></li><li class=chu2><a href=http://www.0917cc.com?ID='+userid+' target=_blank><img src=/WebSystems/images/img/icons/gif/group.png /></a> <a href=javascript:void(0) onclick=getFirend("'+ user +'"); ><font class=ChatFont1>(' + user + ')</font></a> <img src=/WebSystems/images/img/icons/gif/male.png /> <a href=javascript:void(0) onclick=getFirend("'+ userto +'");><font class=ChatFont2>' + userto + '</font></a> <font color=#575D69>说</font> <font color=#575D69>' + date +'</font>'+delhtml+'<br>' + text+ '</li></ul></div>';
182               chatEL.append(chatELinnerHTML);
183               }
184   lastID = umax;//上次消息的ID
185   chatEL.scrollTop(document.getElementById("chat").scrollHeight);//滚动到最后一条消息
186   if(!isposted){
187   isposted = true;
188   getMess();
189   }
190 }
191
192
193
194 //未从服务器得到数据,继续查询
195 if(succ==0){
196 lastID = sid;//上次消息的ID
197 chatEL.scrollTop = chatEL.scrollHeight;//滚动到最后一条消息
198 if(!isposted){
199 isposted = true;
200 getMess();
201 }
202 }
203});
204 //each--end
205            },
206            //-success-end
207            //Ajax请求超时,继续查询
208            error:function(XMLHttpRequest,textStatus,errorThrown){
209                      if(textStatus=="timeout"){
210                        $("#msg").show().html("您有好长时间没有发言了啊.").fadeOut(3200);
211                        if(!isposted){
212 isposted = true;
213 getMess();
214 }
215                      }
216            }
217
218             });
219
220 }
  
  
  *本聊天系统采用PHP+AJAX+MYSQL开发而成!数据库支持mysql,支持XML,支持txt,支持accsess等数据库,可随意转换
聊天功能:1:表情2:超链接3:发送图片,4发送文件,5字体设置,6涂鸦功能
功能:可以对某个人说话,也可以对所有人说话,支持私聊(vip功能)
支持PHP长连接sleep实现的聊天室源码跟ajax实现的聊天室代码
作者:margin(qq:249189520----qq群:90316079-----账号1:admin密码:admin   账号2:demo 密码:demo
  官方网站:http://www.0917cc.com
  PHP+ajax聊天室模拟推送http://room.0917y.com/websystems/Chatroom2/
  可以在火狐FF下查看连接进程跟下面的有什么不一样
PHP+ajax聊天室http://room.0917y.com/websystems/Chatroom/index.php?pid=25&ppid=64
  *模拟推送是根据PHP长连接sleep实现的
  不足跟缺点:
一直困惑了我一晚上都没有解决的问题是,在编辑器开头第一个插入空格的话!老是提示错误!好像跟XML规范有关系!
又好像是编辑器ueditor的问题取出来的空格会有c2a0会变成乱码,处理这种情况\u00a0不知道怎么处理
服务器的过滤不行!客户的过滤还不行!请求高手看下....
  
  
  
页: [1]
查看完整版本: PHP+ajax聊天室源码!支持长轮循跟定时请求两种