Html实现局部发送验证(页面不跳转)

本文介绍如何使用HTML和后台API实现在不刷新页面的情况下,用户输入邮箱并获取和验证验证码的过程,重点在于POST请求和Controller的处理方式。

Html实现局部发送验证(页面不跳转)

场景

在这里插入图片描述

1、html页面

<label class="txtin-box">
    <input class="txtin" type="email" id="email" name="email" placeholder="邮箱" required/>
</label>
<label class="txtin-box txtin-box-code">
    <input class="txtin" type="text" name="vercode" placeholder="邮箱验证码" required/>
    <a onclick="getkey(this)" id="get-yzm" class="get-yzm">获取验证码</a>
</label>
<script>
    function getkey(a){
        var email='email='+document.getElementById("email").value;
        var request = new XMLHttpRequest();
        request.open("POST", "/send?"+email);
        request.send(email)
    }

</script>

2、controller控制层

@RequestMapping("/send")
@ResponseBody
public void sendMessage(@RequestParam("email") String email,
                        HttpSession session){
    //发送验证码
    CodeUtil codeUtil=new CodeUtil();
    //获取六位验证码
    String randomCode = codeUtil.getRandomCode(6);
    //先清除session域
    session.removeAttribute("checkCode");
    //加密验证码存放session域中
    session.setAttribute("checkCode",codeUtil.passwordEncoder().encode(randomCode));
    sendMessage.sendMessage(email,randomCode);
}

这个地方注意,一定要返回void类型,必须加@ResponseBody注解

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

芝兰生于深谷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值