aspx页面调用发送邮件验证码(结合前两篇)
<%@ 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="请输入邮箱" />
<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页面调用发送邮件验证码(结合前两篇)的更多相关文章
- 前两篇转载别人的精彩文章,自己也总结一下python split的用法吧!
前言:前两篇转载别人的精彩文章,自己也总结一下吧! 最近又开始用起py,是为什么呢? 自己要做一个文本相似度匹配程序,大致思路就是两个文档,一个是试题,一个是材料,我将试题按每题分割出来,再将每题的内 ...
- aspx页面调用webapi接口报错:远程服务器返回错误:(500)内部服务器错误
代码在运行到response = (HttpWebResponse)request.GetResponse();就开始报错 原因:可能因为所调用的接口不存在或者接口中存在错误,可用postman测试接 ...
- SpringMvc支持Ajax概述【见前两篇随笔--详述前后数据互通】
1.原生javaWeb:不再用 1).导入GSON: 2).返回的数据用GSON转成json 3).写出去: 2.SpringMVC快速的完成ajax功能? 导包 jackson-annotation ...
- 微信公众号支付(三):页面调用微信支付JS并完成支付
一.调用微信的JS文件 1.首先要绑定[JS接口安全域名],“公众号设置”的“功能设置”中 2.引入JS文件 备注:支持使用 AMD/CMD 标准模块加载方法加载 <script type=&q ...
- 用mvc模式,整理前两次的代码并增加登陆注册
简单的servlet连接mysql数据库 使用mvc的登录注册 commons-dbutils-1.6 mysql-connector-java-5.1.40-bin c3p0-0.9.5.2 mch ...
- wp-query调用前几篇文章的方法
---恢复内容开始--- 利用强大的wp-query函数调用指定分类下的前几篇文章,下面的代码表示调用的是分类ID4下的前两篇文章. <?php $cunt_wenzhen = array('c ...
- Jquery Ajax调用aspx页面方法
Jquery Ajax调用aspx页面方法 在asp.net webform开发中,用jQuery ajax传值一般有几种玩法 1)普通玩法:通过一般处理程序ashx进行处理: 2)高级玩法:通过as ...
- webform工程中aspx页面为何不能调用appcode文件夹下的类(ASP.NET特殊文件夹的用法)
App_code 只有website类型的工程才有效. App_Code 下创建的.cs文件仅仅是“内容”不是代码.你设置那个文件为“编译”就行了. 其他特殊文件夹 1. Bin文件夹 Bin文件夹包 ...
- jquery.ajax请求aspx和ashx的异同 Jquery Ajax调用aspx页面方法
1.jquery.ajax请求aspx 请求aspx的静态方法要注意一下问题: (1)aspx的后台方法必须静态,而且添加webmethod特性 (2)在ajax方法中contentType必须是“a ...
随机推荐
- Js日期函数Date格式化扩展
prototype是向对象中添加属性和方法,返回对象类型原型的引用,例如对js中日期函数Date进行扩展: Date.prototype.Format = function (fmt) { var o ...
- How do I remove javascript validation from my eclipse project?
Right click your project Select Properties -> JavaScript -> Include Select Source tab (It look ...
- 通过反射获得 spring 的 RequestMapping value值
package demo import java.lang.reflect.Method; import org.springframework.web.bind.annotation.Request ...
- How-to: Enable User Authentication and Authorization in Apache HBase
With the default Apache HBase configuration, everyone is allowed to read from and write to all table ...
- memcached tomcat maven 学习记录
2016.12.11 maven 快速搭建项目,只要有pom.xml文件配置好依赖 可以把项目切割(具体切割出来的块怎么用?) nginx 负载均衡 文件服务器 主要配置nginx.conf 文件 ...
- Managing IIS Log File Storage
Managing IIS Log File Storage You can manage the amount of server disk space that Internet Informa ...
- xargs的原理剖析及用法详解
转载请注明出处:http://www.cnblogs.com/f-ck-need-u/p/5925923.html 学习这个xargs花了很长时间,在网上翻了很久也查了很多书关于xargs的介绍,都只 ...
- 关于 Dev中的GridControl 中 GridView 的 PopulateColumns() 方法
最近使用Dev控件,Gridview绑定数据源后不能显示数据,于是在网上查询,说是使用PopulateColumns()方法,可以显示数据.试了一下,管用. 于是在所有更新数据源数据后,都用上了这句话 ...
- prolog 内部谓词
内部谓词 和其他语言一样,prolog也提供一些基本的输入输出函数. 内部谓词是指已经在prolog中事先定义好的谓词,在内存中的动态数据库中是没有内部谓词子句的.(当我们运行某个.pl 文件的时候, ...
- jsPlumb的简单使用
jsPlumb概述jsPlumb是一个在dom元素之间绘制连接线的javascript框架,它使用svg技术绘制连接线. 基本概念很明显,一个连线主要要解决的问题包括谁和谁连,在哪里连(连接点在哪里) ...