本来这个CP是单发的SMS接口,由于种种原因需要实现群发,每次编辑一条信息,群发网站所有会员(上万条会员记录),程序难点在从MYSQL到MSSQL不同数据库服务器间万行记录记录插入更新,并实时发送进度显示,反馈发送后的结果。
在短信发送过程中有以下几个要求:
1)不允许出现程序超时现象; 2)自动检测手机号码的合法性;3)计算发送的进度比例;
4)从MYSQL到MSSQL不同数据库服务器间万行记录记录插入更新,SQL语句不超负荷;
简单描述解决方法:
利用JQ 中一个AJAX脚本 递交 发送短信记录申请,程序读取申请记录,用SESSION记录下进度数据,根据每次发送的条数,返回记录中的未发送短信的手机号码,发送程序之前加手机合法性验证。AJAX接受到第一次返回记录数据,将手机号码提交给一个递归函数,再在函数中重复递交剩余的手机号码,直到进度为100%。
不知道我又没有说明白,参考代码如下:
function send_onesms(s,p,sendid){ //这个是第一个AJAX发送
if (sendid==''''){
$.prompt(''你还没有选择要发送的短信?'',{buttons:{确定:true}});
return false;
}
var totel = '''';
$(''#loading'').show();
$.ajax({
timeout: 36000,
type: "GET",
url: "/admincp/page.php",
data: "showtype=2&page="+p+''&sendid=''+sendid,
beforeSend: function(){
$.ajax({async:true,url: "/admincp/jindu.php?act=clear&rnd="+new Date().getTime(), success: function(response){$("#jindu").html(response);}, dataType: "html"});
$(''a.sendclass'').html(''锁定状态'').removeAttr("onclick");
$(''#sid''+sendid).html(''发送中...'').removeAttr("onclick");
},
success: function(msg){
$(''#i2page'').val=p;
//$(''#smslist'').html(unescape(msg));
//$(''#loading'').hide();
if (msg!=''over''){
totel = msg;
// setInterval(function() { $.ajax({async:true,url: "/admincp/jindu.php?rnd="+new Date().getTime(), success: function(response){$("#jindu").html(response);}, dataType: "html"}) },1000);
}
}
});
send_sms(s,p,sendid,totel);
//window.clearInterval(thread);
}
function send_sms(s,p,sendid,totel){ //一个递归函数
$.ajax({
timeout: 36000,
dataType: "html",
type: "POST",
url: "/admincp/page.php?rnd="+new Date().getTime(),
data: "showtype=2&page |