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); 
}
  • 25
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
实现发送手机短信验证码和邮箱验证码的注册登录功能可以分为以下几步: 1. 获取用户输入的手机号或邮箱地址,点击发送验证码按钮后,向后台发起请求。 2. 后台接收到请求后,生成随机验证码,并将验证码保存到后台或发送到用户手机或邮箱中。 3. 用户输入验证码后,前端将用户输入的验证码和后台保存的验证码进行比对,验证成功后,允许用户完成注册或登录操作。 具体实现方法如下: 1. 发送手机短信验证码 (1)引入阿里云短信SDK,可以使用以下代码发送短信验证码: ```java DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "<accessKeyId>", "<accessSecret>"); IAcsClient client = new DefaultAcsClient(profile); CommonRequest request = new CommonRequest(); request.setMethod(MethodType.POST); request.setDomain("dysmsapi.aliyuncs.com"); request.setVersion("2017-05-25"); request.setAction("SendSms"); request.putQueryParameter("PhoneNumbers", "<手机号>"); request.putQueryParameter("SignName", "<短信签名>"); request.putQueryParameter("TemplateCode", "<短信模板>"); request.putQueryParameter("TemplateParam", "{\"code\":\"" + code + "\"}"); CommonResponse response = client.getCommonResponse(request); String result = response.getData(); ``` 其中,<accessKeyId>和<accessSecret>是阿里云账号的AccessKey ID和AccessKey Secret,<手机号>是用户输入的手机号,<短信签名>和<短信模板>需要在阿里云管理控制台中进行配置,<code>是生成的短信验证码。 (2)后台保存验证码,可以使用session或Redis等进行保存。 2. 发送邮箱验证码 (1)引入JavaMail API,可以使用以下代码发送邮件验证码: ```java Properties props = new Properties(); props.setProperty("mail.smtp.host", "<SMTP服务器地址>"); props.setProperty("mail.smtp.auth", "true"); props.setProperty("mail.smtp.port", "<SMTP服务器端口>"); props.setProperty("mail.smtp.ssl.enable", "true"); Session session = Session.getDefaultInstance(props, new Authenticator() { protected PasswordAuthentication getPasswordAuthentication() { return new PasswordAuthentication("<邮箱地址>", "<邮箱密码>"); } }); String code = generateCode(); // 生成随机验证码 Message message = new MimeMessage(session); message.setFrom(new InternetAddress("<发件人邮箱>")); message.setRecipient(Message.RecipientType.TO, new InternetAddress("<收件人邮箱>")); message.setSubject("<邮件主题>"); message.setText("您的验证码是:" + code); Transport.send(message); ``` 其中,<SMTP服务器地址>和<SMTP服务器端口>是邮箱服务商提供的SMTP服务器地址和端口号,<邮箱地址>和<邮箱密码>是发送邮件的邮箱地址和密码,<发件人邮箱>和<收件人邮箱>是邮件的发送者和接收者,<邮件主题>是邮件的主题,<code>是生成的邮箱验证码。 (2)后台保存验证码,可以使用session或Redis等进行保存。 3. 验证码校验 (1)前端发送验证码后,用户输入验证码,可以使用以下代码进行验证码校验: ```javascript $.ajax({ url: "<后台校验验证码接口>", type: "POST", data: { code: "<用户输入的验证码>" }, success: function (result) { if (result.code === 0) { alert("验证码校验成功"); } else { alert("验证码校验失败"); } } }); ``` (2)后台校验验证码,可以使用以下代码进行验证: ```java String code = request.getParameter("code"); // 获取用户输入的验证码 String sessionCode = (String) request.getSession().getAttribute("<验证码在session中的key>"); if (code.equals(sessionCode)) { // 验证码校验成功 } else { // 验证码校验失败 } ``` 其中,<验证码在session中的key>是验证码在session中保存的key值。如果验证码保存在Redis中,则需要通过Redis API进行获取。 以上就是实现发送手机短信验证码和邮箱验证码的注册登录功能的方法。需要注意的是,发送短信验证码和发送邮箱验证码的代码实现方式有所不同,开发者需要根据实际情况进行选择。同时,为了保证验证码的安全性,建议对短信验证码和邮箱验证码进行有效期限制和防刷措施。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值