js ajax实现短信验证码功能

9 篇文章 0 订阅
8 篇文章 1 订阅

这是一个简单的前台短信验证码功能 ajax实现异步处理 (发送和校验)

js代码

<script type="text/javascript"> 


var InterValObj; //timer变量,控制时间
var count = 60; //间隔函数,1秒执行
var curCount;//当前剩余秒数
function sendMessage() {
curCount = count;
// 设置button效果,开始计时
document.getElementById("btnSendCode").setAttribute("disabled","true" );//设置按钮为禁用状态
document.getElementById("btnSendCode").value="请在" + curCount + "后再次获取";//更改按钮文字
InterValObj = window.setInterval(SetRemainTime, 1000); // 启动计时器timer处理函数,1秒执行一次
// 向后台发送处理数据
$.ajax({
type: "POST", // 用POST方式传输
dataType: "text", // 数据格式:JSON
url: "forgetPasswdServlet", // 目标地址
data: "flag=2",
success: function (data){ 
data = parseInt(data, 10);
if(data == 1){
$("#jbPhoneTip").html("<font color='#339933'>√ 短信验证码已发到您的手机,请查收</font>");
                }else if(data == 0){
$("#jbPhoneTip").html("<font color='red'>× 短信验证码发送失败,请重新发送</font>");
}
}
});
}

//timer处理函数

function SetRemainTime() {
if (curCount == 0) {                
window.clearInterval(InterValObj);// 停止计时器
document.getElementById("btnSendCode").removeAttribute("disabled");//移除禁用状态改为可用
document.getElementById("btnSendCode").value="重新发送验证码";
}else {
curCount--;
document.getElementById("btnSendCode").value="请在" + curCount + "秒后再次获取";
}
}

 //验证短信验证码
 function doCompare(){

var codelast = document.getElementById("codelast").value;//获取输入的验证码
if(codelast == null || codelast == ''){
alert("验证码不能为空!");
}else{

$.ajax({
type: "POST", // 用POST方式传输
dataType: "text", // 数据格式:JSON
url: "forgetPasswdServlet", // 目标地址
data: "flag=4&codelast="+codelast,
success: function (data){ 
data = parseInt(data, 10);
if(data == 1){
  window.location.href='/aoyi/forgetpasswd/forgetpasswd3.jsp';//验证成功
                }else if(data == 0){
$("#jbPhoneTip").html("<font color='red'>×短信验证码不正确请重新输入</font>");
}else if(data ==2){
$("#jbPhoneTip").html("<font color='red'>×验证码已失效请重新获取验证码</font>");
}
}
});
     }
}

</script> 

jsp部分代码

 <tr>
              <td>
                             <input id="btnSendCode" name="btnSendCode" type="button"   value="点击获取验证码" onclick="sendMessage();" />
              </td>

  </tr>

  <tr>

             <td align="center"  style="font-size: 18px;font-weight:bold; ">
                 输入验证码:<input style="height: 25px" type="text" name="codelast" id="codelast">
             </td>
</tr>

<tr>             
              <td align="center"><span id="jbPhoneTip"></span></td>//根据后台返回data值显示不同信息
 </tr>

 <tr>

              <td align="center"><input type="button" onClick="doCompare();" value="下一步"  class="button4"></td>

 </tr>

发送验证码接口

/**
* 发送验证码
* @Title: setCode
* @Description: TODO
* @param @param request
* @param @param response
* @param @throws ServletException
* @param @throws IOException    
* @return void    
* @throws
*/
public void setCode(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{
HttpSession session = request.getSession();

JSONHttpClient jsonHttpClient = JSONHttpClient.getInstance("wt.3tong.net");
String phonenum = (String)session.getAttribute("phonenum");

response.setContentType("application/x-javascript");
Random random = new Random();
String srand="";
for (int i = 0; i < 4; i++) {
String rand = String.valueOf(random.nextInt(10));
// String rand = getRandChar();
srand += rand;
}
String content = "您的验证码为"+srand+"请注意妥善保存!";// 短信内容(必填)
//System.out.println(content);
String sendRes = jsonHttpClient.sendSms(phonenum, content);
JSONObject json = JSONObject.fromObject(sendRes);
String data="1";
if(!"0".equals(json.get("result"))){
data="0";
}
   session.setAttribute("code", srand); //将验证码保存在session中
   response.setContentType("application/json;charset=UTF-8");  
        response.setHeader("Cache-Control", "no-cache");  
        PrintWriter out = response.getWriter();  
        out.write(data);  
   //request.getRequestDispatcher("/forgetpasswd/forgetpasswd2.jsp").forward(request, response);


}

验证验证码接口

/**
   * 校验验证码
   * @Title: checkCode
   * @Description: TODO
   * @param @param request
   * @param @param response
   * @param @throws ServletException
   * @param @throws IOException    
   * @return void    
   * @throws
   */
public void checkCode(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException{


String codelast = request.getParameter("codelast");//获取前台传来的用户输入的验证码
Object code=request.getSession().getAttribute("code"); //获取session中的验证码
 String data ="1";
   if(null==code){
    data="2";
   }else if(!code.equals(codelast)){
    data="0";
   }
response.setContentType("application/json;charset=UTF-8");  
        response.setHeader("Cache-Control", "no-cache");  
        PrintWriter out = response.getWriter();  
        out.write(data); 
}
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值