var lastID = "1";//声明上次取回的消息的ID
var isposted = false;
var mGetTime;//设置setTimeout的返回值
// 通过封装getAjax()方法创建XMLHTTPRequest对象
function trim(str){ //删除左右两端的空格
 return str.replace(/(^\s*)|(\s*$)/g, "");
} function getPlainTxt() {
var str=UE.getEditor('myEditor').getContent()
str=trim(str);
$('#mess').html(str);
} function setContentmess() {
UE.getEditor('myEditor').setContent('', false);
return;
} //获取JSURL后面的参数
function _getArgs(name,_number){
var jsFileName = name;
var rName = new RegExp(jsFileName+"(\\?(.*))?$")
var jss=document.getElementsByTagName('script');
for (var i = 0;i < jss.length; i++){
var j = jss[i];
if (j.src&&j.src.match(rName)){
var oo = j.src.match(rName)[2];
if (oo&&(t = oo.match(/([^&=]+)=([^=&]+)/g))){
for (var l = 0; l < t.length; l++){
r = t[l];
var tt = r.match(/([^&=]+)=([^=&]+)/);
if (tt)
return tt[_number];
//document.write('参数:' + tt[1] + ',参数值:' + tt[2] + '<br />');
}
}
}
}
} function user_to(){
var userid1=$('#userid1').val();
if(userid1=='所有人'){
alert('请选择聊天对象哦!\n\n点击用户名称即可!');
$("#userid2").attr("checked",false);
}
return false;
} //点击选择用户
function getFirend(name) {
var new_name;
if(name.length > 1 && name!="所有人") {
$("#userto").val(name);
$("#userid1").attr("checked",false);
$("#userid2").attr("checked",true); if(name.length > 8) {
new_name = name.substr(0, 6);
} else {
new_name = name;
}
document.getElementById("tousertitle").innerHTML = "<font color=#ff6600 title=" + new_name + ">" + new_name + "</font>";
}else{ $("#userto").val("所有人"); $("#userid1").attr("checked",true);
$("#userid2").attr("checked",false); document.getElementById("tousertitle").innerHTML = "用户";
}
} //发送消息的方法
function sendMess()
{ getPlainTxt();
//如果消息为空给出提示并返回
var messvalue =$("#mess").html();
messvalue=trim(messvalue); if(messvalue.length>650){
alert("参与互动提示:\n亲,输入的文字是不是有点多了?!,少说点吧!\n\n复制过来的文字!请先清除格式!");
//document.getElementById("mess").focus();//把焦点设置到消息输入框
return false;
} if($("#mess").html().length<2){
alert("参与互动提示:\n请填写您要发表的内容,长度必须2~250个字节!");
//document.getElementById("mess").focus();//把焦点设置到消息输入框
return false;
} var d = new Date();
var username = $("#username").val() ;
var userto = $("#userto").val() ;
var userid = $("#userid").val() ;
//var mess = document.getElementById("mess").value ;
var mess = messvalue ;
var userpid = $("#userpid").val() ;
var IP = $("#IP").val() ;
var usertype = $("#usertype").val() ; var sendUrl = "username="+username+"&userto="+userto+"&userid="+userid+"&userpid="+userpid+"&mess="+mess +"&IP="+IP +"&usertype="+usertype+"&d="+d.getTime();
var sendUrl = encodeURI(sendUrl);
XMLHttp.sendReq('POST', 'send.php',sendUrl, send_response); } function send_response(obj){
var response = obj.responseText;
if(response=='ok'){
if(!isposted){
isposted = true;
getMess();
}
setContentmess();//设置消息框为空
}
if(response=='false'){
alert("发送失败!你的字符含有非法字");
getMess();
}
} function getMess(){
var d = new Date(); var getUrl = "getmess.php?lastid="+lastID +"&numbermess=80&d="+d.getTime();//从服务器返回消息的地址
$.ajax({
type:"GET",
dataType:"xml",
url:getUrl,
async: true,
timeout:80000, //ajax请求超时时间80秒 success:function(data,textStatus){
//从服务器得到数据,显示数据并继续查询
isposted = false;
var chatEL = $("#chat");
$(data).find("message").each(function(i,va){
var sid =$(this).find("sid").text();
var succ =$(this).find("succ").text();
var umax =$(this).find("umax").text();
var user =$(this).find("user").text();
var userto =$(this).find("userto").text();
var userid =$(this).find("userid").text();
var usersex =$(this).find("usersex").text();
var usertype =$(this).find("usertype").text();
var userpic =$(this).find("userpic").text();
var userpid =$(this).find("userpid").text();
var text =$(this).find("text").text();
var date =$(this).find("date").text();
var uid = _getArgs('function.js','2')
//有数据 if(succ==1){
if(uid>=98){
delhtml='<a href="#" id="delmess" onclick=delmess("'+ sid +'","delmess");>[删除]</a><a href="#" onclick=delmess("'+ userid +'","delusermess"); id="delusermess">[删除该用户的全部信息]</a>';
}else{
delhtml='';
}
if(usertype>=98){
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>';
chatEL.append(chatELinnerHTML);
}else{
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>';
chatEL.append(chatELinnerHTML);
}
lastID = umax;//上次消息的ID
chatEL.scrollTop(document.getElementById("chat").scrollHeight);//滚动到最后一条消息
if(!isposted){
isposted = true;
getMess();
}
} //未从服务器得到数据,继续查询
if(succ==0){
lastID = sid;//上次消息的ID
chatEL.scrollTop = chatEL.scrollHeight;//滚动到最后一条消息
if(!isposted){
isposted = true;
getMess();
}
}
});
//each--end
},
//-success-end
//Ajax请求超时,继续查询
error:function(XMLHttpRequest,textStatus,errorThrown){
if(textStatus=="timeout"){
$("#msg").show().html("您有好长时间没有发言了啊.").fadeOut(3200);
if(!isposted){
isposted = true;
getMess();
}
}
} }); }

*本聊天系统采用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不知道怎么处理
服务器的过滤不行!客户的过滤还不行!请求高手看下....

PHP+ajax聊天室源码!支持长轮循跟定时请求两种的更多相关文章

  1. Netty聊天室-源码

    目录 Netty聊天室 源码工程 写在前面 [百万级流量 聊天室实战]: [分布式 聊天室] [Spring +Netty]: [Netty 原理] 死磕 系列 [提升篇]: [内力大增篇]: 疯狂创 ...

  2. Unity手游之路<三> 基于Unity+Java的聊天室源码

    http://blog.csdn.net/janeky/article/details/17233199 项目介绍 这是一个简单的Unity项目,实现最基本的聊天室群聊功能.登录聊天室后,用户可以输入 ...

  3. 曹工说Spring Boot源码(14)-- AspectJ的Load-Time-Weaving的两种实现方式细细讲解,以及怎么和Spring Instrumentation集成

    写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...

  4. java Activiti6 工作流引擎 websocket 即时聊天 SSM源码 支持手机即时通讯聊天

    即时通讯:支持好友,群组,发图片.文件,消息声音提醒,离线消息,保留聊天记录 (即时聊天功能支持手机端,详情下面有截图) 工作流模块---------------------------------- ...

  5. javaweb聊天室源码免费

    效果:可擴展源碼,免費技術指導,電話13956301647 链接:https://pan.baidu.com/s/1FWV8DNWacGaEpAQEsWsNaw 提取码:b6gf

  6. iOS 即时通讯 + 仿微信聊天框架 + 源码

    这些你造吗? 即时通讯(IM),在IOS这片江湖里面已经算是一个老者了,我这小旋风也是在很早以前巡山的时候,就知道有即时通讯这个妖怪,以前也多多少少接触过一些,在造APP的时候用过,哎呀,说着说着就感 ...

  7. 修改Cosbench源码 支持s3的 http range request 测试场景

    在视频点播的业务应用场景中,用户使用了ffmpeg工具做视频实时转码用. 而ffmpeg使用range 请求.而Cosbench不支持这种测试场景,所以需要修改源码支持这种测试场景. HTTP 协议介 ...

  8. 修改json源码支持datetime序列化

    修改json源码支持datetime序列化 import json import datetime now = datetime.datetime.today() json.dumps(now) 抛出 ...

  9. Redis源码阅读(四)集群-请求分配

    Redis源码阅读(四)集群-请求分配 集群搭建好之后,用户发送的命令请求可以被分配到不同的节点去处理.那Redis对命令请求分配的依据是什么?如果节点数量有变动,命令又是如何重新分配的,重分配的过程 ...

随机推荐

  1. java内部类的继承

    1.public class OuterInnerClass extends ClassA.ClassB{        public OuterInnerClass(ClassA a)       ...

  2. 再战map

    以前自己整理过map容器,但是好像没有这篇这么系统... Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据 处 ...

  3. 安装express后却找不到express的命令

    1.全局安装express npm install -g express 2.执行express命令,创建web项目框架 express -e ejs myweb 会提示 express 不是内部或外 ...

  4. canvas-a10isPointPath2.html

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. <路径算法>哈密顿路径变种问题(2016华为软件精英挑战赛初赛)

    原创博客,转载请联系博主! 前言:几天前华为的这个软件精英(算法外包)挑战赛初赛刚刚落幕,其实这次是我第二次参加,只不过去年只入围到了64强(32强是复赛线),最后搞到了一个华为的一顶帽子(感谢交大l ...

  6. qemu-kvm和openvswitch安装部署-qemu-kvm和openvswitch原型环境部署和基本测试 (1)

    qemu-kvm和openvswitch安装部署 本文包含两个部分: qemu-kvm的安装部署 openvswitch的安装部署 参考文档: kvm官网:http://www.linux-kvm.o ...

  7. python中若干错误

    今天在运行的django的时候一直提示”系统错误“,如下 except Exception, ex: logger.error(printException()) return render_stri ...

  8. 学习记录 java随机数的产生机制

    java 随机数 一.在j2se里我们可以使用Math.random()方法来产生一个随机数,这个产生的随机数是0-1之间的一个double,我们可以把他乘以一定的数,比如说乘以100,他就是个100 ...

  9. mongodb分组,的两种方式,先记一下

    using MongoDB.Bson; using MongoDB.Driver; using MongoDB.Driver.Builders; using NationalUnion.AdGalle ...

  10. java服务器

    WebLogic BEA公司开发的(被Oracle收购了)收费的 支持JavaEE所有的规范(ejb servlet/jsp规范) java  mysql(oracle)      2.WebSphe ...