<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default3.aspx.cs" Inherits="Default3" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript" language="javascript">
        var times = 60;
        function FunCanUse() {
            if ($("#Email").val() == "") {
                $("#<%=this.Label1.ClientID %>").html("请输入邮箱");
            }
            else {
                var t;
                var partten = /^(\w)+(\.\w+)*@(\w)+((\.\w+)+)$/;
                if (!partten.test(document.getElementById("Email").value)) {
                    return;
                }
                if (times == 60) {
                    var Email = $("#Email").val();
                    $.ajax({
                        type: "GET",
                        dataType: "json",
                        url: '<%=ResolveUrl("~")%>EmailRandCode.ashx',
                        data: "email=" + encodeURIComponent(Email) + "&action=delete&T=" + new Date(),
                        success: function (result) {
                        }
                    })
                }
                document.getElementById('btnSendCheckCode').style.display = "none";
                times = times - 1;
                document.getElementById('btnCode').style.display = "block";
                document.getElementById('btnCode').value = times + "秒后重新获取";

t = setTimeout('FunCanUse()', 1000); //1秒后启用

if (times == 0) {
                    clearTimeout(t);
                    times = 60;
                    document.getElementById('btnSendCheckCode').value = '重新发送验证码';
                    document.getElementById('btnSendCheckCode').style.display = "block";
                    document.getElementById('btnCode').style.display = "none";
                }
            }

}
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <label class="lb">
            <span class="required">*</span>邮箱</label>
        <input id="Email" type="text" runat="server" class="ipt-t" tabindex="2" placeholder="请输入邮箱" />
        &nbsp;&nbsp;&nbsp;&nbsp;<asp:Label ID="Label1" runat="server" Text="" ForeColor="Red"></asp:Label>
        <a id="btnSendCheckCode" onclick="FunCanUse()" href="#" style="display: block; width: 80px;
            margin-left: 280px; font-size: 12pt;">发送验证码</a>
        <input id="btnCode" type="button" value="" style="width: 180px; margin-top: 5px;" />
    </div>
    </form>
</body>

</html>

aspx.sc 后台验证

页面验证(aspx页面)

if (Request.Cookies["EmailRandCode"] != null)
        {
            string strCheckCode = HttpUtility.UrlDecode(Request.Cookies["EmailRandCode"].Values[0].ToString());
            string strCurDateTime = HttpUtility.UrlDecode(Request.Cookies["EmailRandCode"].Values[1].ToString());
            //判断是否过期,若不过期,
            DateTime dt = DateTime.Parse(strCurDateTime);
            DateTime dtNow = System.DateTime.Now;
            TimeSpan spT = dtNow - dt;
            if (spT.TotalSeconds <= 180)
            {
                if (strCheckCode != txtCheckCode.Text.Trim())
                {
                    this.AddResponseWriteScript("alert('验证码错误!');");
                    return;
                }
            }
            else if (txtCheckCode.Text.Trim() == "")
            {
                this.AddResponseWriteScript("alert('请输入验证码!');");
                return;

}
            else
            {
                this.AddResponseWriteScript("alert('验证码过期,请重新获取!');");
                return;
            }
        }
        else if (txtCheckCode.Text.Trim() == "")
        {
            this.AddResponseWriteScript("alert('请输入验证码!');");
            return;
        }
        else
        {
            this.AddResponseWriteScript("alert('验证码过期,请重新获取!');");
            return;
        }

aspx页面调用发送邮件验证码(结合前两篇)的更多相关文章

  1. 前两篇转载别人的精彩文章,自己也总结一下python split的用法吧!

    前言:前两篇转载别人的精彩文章,自己也总结一下吧! 最近又开始用起py,是为什么呢? 自己要做一个文本相似度匹配程序,大致思路就是两个文档,一个是试题,一个是材料,我将试题按每题分割出来,再将每题的内 ...

  2. aspx页面调用webapi接口报错:远程服务器返回错误:(500)内部服务器错误

    代码在运行到response = (HttpWebResponse)request.GetResponse();就开始报错 原因:可能因为所调用的接口不存在或者接口中存在错误,可用postman测试接 ...

  3. SpringMvc支持Ajax概述【见前两篇随笔--详述前后数据互通】

    1.原生javaWeb:不再用 1).导入GSON: 2).返回的数据用GSON转成json 3).写出去: 2.SpringMVC快速的完成ajax功能? 导包 jackson-annotation ...

  4. 微信公众号支付(三):页面调用微信支付JS并完成支付

    一.调用微信的JS文件 1.首先要绑定[JS接口安全域名],“公众号设置”的“功能设置”中 2.引入JS文件 备注:支持使用 AMD/CMD 标准模块加载方法加载 <script type=&q ...

  5. 用mvc模式,整理前两次的代码并增加登陆注册

    简单的servlet连接mysql数据库 使用mvc的登录注册 commons-dbutils-1.6 mysql-connector-java-5.1.40-bin c3p0-0.9.5.2 mch ...

  6. wp-query调用前几篇文章的方法

    ---恢复内容开始--- 利用强大的wp-query函数调用指定分类下的前几篇文章,下面的代码表示调用的是分类ID4下的前两篇文章. <?php $cunt_wenzhen = array('c ...

  7. Jquery Ajax调用aspx页面方法

    Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...

  8. webform工程中aspx页面为何不能调用appcode文件夹下的类(ASP.NET特殊文件夹的用法)

    App_code 只有website类型的工程才有效. App_Code 下创建的.cs文件仅仅是“内容”不是代码.你设置那个文件为“编译”就行了. 其他特殊文件夹 1. Bin文件夹 Bin文件夹包 ...

  9. jquery.ajax请求aspx和ashx的异同 Jquery Ajax调用aspx页面方法

    1.jquery.ajax请求aspx 请求aspx的静态方法要注意一下问题: (1)aspx的后台方法必须静态,而且添加webmethod特性 (2)在ajax方法中contentType必须是“a ...

随机推荐

  1. MATLAB 文件对话框之图片格式转换

    localpathname为当前路径,需要保存图片的位置,根据自己的实际路径设置,usedpathname用来保存打开的文件位置,方便下次打开文件对话框以上次的路径为默认路径. global used ...

  2. (heartbeat与KeepAlived)

    总拓扑图 两种实现方式: 实验一. LVS+heartbeat+ldirectord实现集群负载: 1.在主Director Server上和备用Director Server上分别安装heartbe ...

  3. 发现大量的TIME_WAIT解决办法

    存在一定的TIME_WAIT是正常的,个人认为如果超过了连接数的比例就不是很正常 服务器端与客户端建立TCP/IP连接后关闭SOCKET后,服务器端连接的端口状态变为TIME_WAIT.主动关闭的一方 ...

  4. 转: windows下面安装Python和pip终极教程

    原文: http://www.cnblogs.com/yuanzm/p/4089856.html 因为如果是初学者在windows环境下安装,简直是折磨人,会遇到各种蛋疼的情况.本文希望提供傻瓜式的教 ...

  5. JSON与XML优缺点对比分析

    本文从各个方面向大家对比展示了json和xml的优缺点,十分的全面细致,有需要的小伙伴可以参考下. 1. 定义介绍 1.1 XML定义 扩展标记语言 (Extensible Markup Langua ...

  6. MFC 关于MFC中CImage的简单使用

    首先要将#include <atlimage.h>加进来,开始时我加到stdafx.h中,但一直提示windows.h被重复引入的问题,后将其加在别的头文件中,就可以了..   --! 一 ...

  7. CSharper 学Quick-Cocos2d-X (一) 开发环境的搭建

    前言   本来想写CSharper 学Cocos2dx系列的.但是最近在了解许多跨平台游戏开发框架后 最终决定使用Quick-cocos2d-x+lua进行第一个游戏项目的开发.经过一天多的折腾 终于 ...

  8. loadrunner ---模拟多IP登录

    1.打开HP LoadRunner ->Tools ->IP Wizard

  9. Altium Designer15 卡在登陆界面解决办法:

    Altium Designer15 卡在登陆界面解决办法: 在我的电脑系统盘中找到下面目录(注:如果看不到,需要取消隐藏文件选项.) C:\Documents and Settings\Adminis ...

  10. 方法的覆盖(override)、重载(overload)和重写(overwrite)

    body { background-color: white } .markdown-body { min-width: 200px; max-width: 760px; margin: 0 auto ...