本来这个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="+p+'&sendid='+sendid+'&totel='+totel,
success: function(response){
if (response!='over'){
$.ajax({async:true,url: "/admincp/jindu.php?rnd="+new Date().getTime(), success: function(response){$("#jindu").html(response);}, dataType: "html"});
setTimeout(send_sms(s,p,sendid,response),1000);
}else{
$.ajax({async:true,url: "/admincp/jindu.php?act=over&rnd="+new Date().getTime(), success: function(response){alert(response);}, dataType: "html"});
$('#loading').hide();
menu_sec2_move(p);
}
}
});
}
发表回复