formValidator输入验证、异步验证实例 + licenseImage验证码插件实例应用
实例技术:springmvc
实现功能:完整用户登录流程、输入信息规则校验、验证码异步校验.
功能清单:
1.springmvc控制器处理get请求(/member/login.html),进行静态页面跳转到用户登录页
2.Springmvc控制器处理post请求(/member/login.html),进行登录实际业务处理
3.验证实例包含常规输入验证 + 异步验证,使用验证插件formValidator
插件下载:
验证插件下载:http://www.cnblogs.com/wzmaodong/archive/2012/10/15/2724005.html [猫冬博客]
验证码插件下载: http://www.cnblogs.com/dennisit/p/3325871.html [苏若年博客]
实例效果:
前端登录样式效果
<div class="content-wp">
<!--登录开始-->
<div class="login-form">
<form action="" method="post" name="formLogin" id="formLogin">
<dl>
<dt>帐户基本信息</dt>
<dd>
<span class="title">登录邮箱:</span>
<input class="login_input" name="email" type="text" id="email"/>
<span id="emailTip" class="onshow"></span>
</dd>
<dd>
<span class="title">登录密码:</span>
<input class="login_input" id="password" name="password" type="password"/>
<span id="passwordTip" class="onshow"></span>
</dd> <dd style="heigth:50px;">
<span class="title">验证码:</span>
<img class="img" id="licenImg" src="${ctx }/licenseImg/loadImage.html?type=5" width="115" height="40" />
<span class="chimgbox">
<a href="javascript:void(0);" id="changeImg">看不清?换一张</a>
</span>
</dd>
<dd>
<span class="title">输入验证码:</span>
<input type="text" id="checkcode" class="login_input" name="checkcode" maxlength="4" />
<span id="checkcodeTip" class="onshow">请输入验证码</span>
</dd>
</dl>
<div class="login_btn_box">
<input id="button" name="button" type="submit" value="免费注册" class="login_btn"/>
<span class="clew_txt">如果您已有帐号,可<a href="javascript:void(0);">直接登录</a></span>
</div>
</form>
</div>
<!--登录结束-->
</div>
这里验证码使用自己搞得一个验证码插件.
<img class="img" id="licenImg" src="${ctx }/licenseImg/loadImage.html?type=5" width="115" height="40" />
里边的type用来指定内置的验证码样式
使用formValidator实现前端验证
1.常规验证
//登录邮箱验证
jQuery("#email").formValidator({
onshow:"6-100个字符",
onfocus:"6-100个字符",
oncorrect:"恭喜你,你输对了",
defaultvalue:"@"
}).inputValidator({
min:6,
max:100,
onerror:"长度非法"
}).regexValidator({
regexp:"^([\\w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([\\w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$",
onerror:"格式不正确"
});
参数说明:
onshow:表示页面加载上来先是的内容
onfocus:表示输入框获取得焦点之后的内容
oncorrect:表示输入正确后的信息
defaultvalue:表示输入框默认值
Onerror:表示验证不通过的错误提示.
2.异步验证
//验证码验证相关
jQuery("#checkcode").formValidator({
onshow:"请输入验证码",
onfocus:"验证码为4个字符",
oncorrect:"恭喜你,你输对了"
}).ajaxValidator({
//请求方式post
type: "post",
//请求处理执行方法,这里采用相对路径
datatype: "json",
oncorrect:"验证码正确",
url: "${ctx}/licenseImg/validImage.html?tm=" + new Date().getTime(),
//请求携带的参数值
success: function(result) { //返回的josn串
if(result==1){
return true; //值不是1表示验证码输入错误
}else{
return false; //表示验证码输入正确
}
},
oncorrect:"恭喜你,你输对了",
onerror: "验证码错误,请重新输入",
onwait : "正在检测验证码,请稍候..."
});
说明:ajaxValidator({...});里边执行异步验证,需要说明的是这里验证传递参数,url中无需带入要验证的内容参数,因为带了也不起作用.比如我这里验证码的输入框Id值为checkcode,而这里url:"${ctx}/licenseImg/validImage.html?validimgvalue=" + jQuery("#checkcode").val(),这种写法,然后再服务端我们用request.getParameter("validimgvalue")获取参数的话获取的是页面初始加载的值,而不是我们输入的值.所以这里的异步验证只要保证request.getParameter("输入框name值")一致,然后使用时间戳保证不缓存就可以在服务端获取到每次输入的值了.
前端验证完整实例
<link rel="stylesheet" type="text/css" href="${ctx }/styles/common/common.css">
<link rel="stylesheet" type="text/css" href="${ctx }/styles/member/member_login.css">
<script src="${ctx }/scripts/jquery-1.2.6.min.js" type="text/javascript" charset="UTF-8"></script>
<script src="${ctx }/scripts/form-validator_min.js" type="text/javascript" charset="UTF-8"></script>
<script src="${ctx }/scripts/member/member_login.js" type="text/javascript" charset="UTF-8"></script>
<script type="text/javascript">
jQuery.noConflict();
</script>
<script type="text/javascript">
jQuery(document).ready(function(){
jQuery.formValidator.initConfig({
formid:"formLogin",
debug:false,
submitonce:true,
onerror:function(msg,obj,errorlist){
alert(msg);
}
});
//登录邮箱验证
jQuery("#email").formValidator({
onshow:"6-100个字符",
onfocus:"6-100个字符",
oncorrect:"恭喜你,你输对了",
defaultvalue:"@"
}).inputValidator({
min:6,
max:100,
onerror:"长度非法"
}).regexValidator({
regexp:"^([\\w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([\\w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$",
onerror:"格式不正确"
});
//登录密码验证
jQuery("#password").formValidator({onshow:"至少6个字符",onfocus:"至少6个字符",oncorrect:"密码合法"}).inputValidator({min:6,empty:{leftempty:false,rightempty:false,emptyerror:"输入有误"},onerror:"输入有误"});
//验证码验证相关
jQuery("#checkcode").formValidator({
onshow:"请输入验证码",
onfocus:"验证码为4个字符",
oncorrect:"恭喜你,你输对了"
}).ajaxValidator({
//请求方式post
type: "post",
//请求处理执行方法,这里采用相对路径
datatype: "json",
oncorrect:"验证码正确",
url: "${ctx}/licenseImg/validImage.html?tm=" + new Date().getTime(),
//请求携带的参数值
success: function(result) { //返回的josn串
if(result==1){
return true; //值不是1表示验证码输入错误
}else{
return false; //表示验证码输入正确
}
},
oncorrect:"恭喜你,你输对了",
onerror: "验证码错误,请重新输入",
onwait : "正在检测验证码,请稍候..."
});
/*点击更换验证码的方法*/
jQuery("#changeImg").click(function(){
var path = "${ctx}";
var url = path + "/licenseImg/loadImage.html?type=5&tm=" + new Date().getTime();
jQuery("#licenImg").attr("src",url);
});
});
</script>
3.验证码插件将样式交给前段控制实现
@Controller
@RequestMapping("/licenseImg")
public class LicenseImageController extends BaseMultiController{ /**
* 生成验证码
*
* @author <a href='mailto:dennisit@163.com'>Cn.pudp(En.dennisit)</a> Copy Right since 2013-11-5 下午03:45:51
*
* @param request
* @param response
* @throws ControllerException
* @throws IOException
*/
@RequestMapping(value={"/loadImage","/loadImage.html"},method={RequestMethod.GET})
public void licenseImage(HttpServletRequest request, HttpServletResponse response)throws ControllerException,IOException{
String type = request.getParameter("type"); response.setHeader("Pragma", "no-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
response.setContentType("image/jpeg"); LicenseImage licenseImage = new LicenseImage(); Map<String, BufferedImage> licenseImg = licenseImage.createImage("org/pudp/util/license/resources/yzm" + type +".png"); String key = (String) licenseImg.keySet().iterator().next(); SessionUtil.getSession(request).setAttribute(CommonConstant.LicenseImageKey,key);
System.out.println("session中的验证码值为:" + key); BufferedImage buffImg = licenseImg.get(key);
ServletOutputStream out = response.getOutputStream();
ImageIO.write(buffImg, "jpeg", out);
out.close();
} /**
* 验证验证码是否输入正确
*
* @author <a href='mailto:dennisit@163.com'>Cn.pudp(En.dennisit)</a> Copy Right since 2013-11-5 下午04:09:47
*
* @param request
* @param response
* @throws ControllerException
*/
@RequestMapping(value={"/validImage","/validImage.html"},method={RequestMethod.GET,RequestMethod.POST})
public void validateLicenseImage(HttpServletRequest request, HttpServletResponse response)throws ControllerException{
int status = -1;
String imageVal = StringUtil.getString(request, "checkcode");
String imageSessionVal = (String) SessionUtil.getSession(request).getAttribute(CommonConstant.LicenseImageKey);
System.out.println("用户输入的值:" + imageVal + ",session中存放的值:" + imageSessionVal);
if(imageSessionVal.equalsIgnoreCase(imageVal)){
//如果相等,表示验证码输入正确
status = 1;
}
JsonUtil.str2Json(status+"", response);
} @Override
public Logger getLogger() {
return Logger.getLogger(this.getClass());
} }
转载请注明出处:[http://www.cnblogs.com/dennisit/p/3410147.html]
formValidator输入验证、异步验证实例 + licenseImage验证码插件实例应用的更多相关文章
- AJAX(二)-实现验证码异步验证功能
案例实现效果 用户在前端输入验证码,按键收起触发异步验证,验证验证码的对错 前端代码 checkcode.jsp <%-- Created by IntelliJ IDEA. User: cxs ...
- 利用js制作异步验证ajax方法()
如何利用js写ajax异步验证.代码如下: window.onload = function(){ var name = document.getElementById('register-name- ...
- MVC验证10-到底用哪种方式实现客户端服务端双重异步验证
原文:MVC验证10-到底用哪种方式实现客户端服务端双重异步验证 本篇将通过一个案例来体验使用MVC的Ajax.BeginForm或jQuery来实现异步提交,并在客户端和服务端双双获得验证.希望能梳 ...
- 在ASP.NET MVC中使用Knockout实践06,自定义验证、异步验证
在上一篇中体验了Knockout.Validation的基本验证,本篇体验自定义验证和异步验证. 自定义验证规则 ko.validation有一个rules属性,专门用来存放验证规则,它是一个键值对集 ...
- jquery登录的异步验证
//定义一个json var validate = { username : false, pwd : false, pwded : false, verify : false, loginUsern ...
- ASP.NET MVC验证 - jQuery异步验证
本文主要体验通过jQuery异步验证. 在很多的教材和案例中,MVC验证都是通过提交表单进行的.通过提交表单,可以很容易获得验证出错信息.因为,无论是客户端验证还是服务端验证,总能找到与Model属性 ...
- MVC验证11-对复杂类型使用jQuery异步验证
原文:MVC验证11-对复杂类型使用jQuery异步验证 本篇体验使用"jQuery结合Html.BeginForm()"对复杂类型属性进行异步验证.与本篇相关的"兄弟篇 ...
- MVC验证09-使用MVC的Ajax.BeginForm方法实现异步验证
原文:MVC验证09-使用MVC的Ajax.BeginForm方法实现异步验证 MVC中,关于往后台提交的方法有: 1.Html.BeginForm():同步 2.Ajax.BeginForm():异 ...
- MVC验证08-jQuery异步验证
原文:MVC验证08-jQuery异步验证 本文主要体验通过jQuery异步验证. 在很多的教材和案例中,MVC验证都是通过提交表单进行的.通过提交表单,可以很容易获得验证出错信息.因为,无论是客户端 ...
随机推荐
- Mongoose Connection best practice
There is often quite a lot of confusion about how best to set up a database connection with Mongoose ...
- rabbitMQ在linux上安装
语言环境安装 一.编译安装方式 1.依赖环境的安装-如果需要用编译安装erlang语言环境,需要安装C++编译. yum -y install make gcc gcc-c++ kernel-deve ...
- [Functional Programming + React] Provide a reasonable default value for mapStateToProps in case initial state is undefined
For example we have a component, it needs to call 'react-redux' connect function. import { compose, ...
- 【转】 Java多态特性:重载和覆写的比较
Java重载: 在同一个类中 方法具有相同的名字,相同或不同的返回值,但参数不同的多个方法(参数个数或参数类型) public class MethoDemo{ public static void ...
- Spring Validation 表单校验
最近开发一个项目,发现字段校验比较多,同事提出使用Validation校验能更方便一些,今天记录下来,供以后参考: 一.在pom.xml中添加依赖: <dependency> <gr ...
- Pig拒绝连接错误
运行Pig时出现错误: Pig Stack Trace --------------- ERROR 1066: Unable to open iterator for alias visit. Bac ...
- ArcGIS Engine问答:为什么地理数据库中不能产生同名要素类
之所以产生这种问题,其原因是不管一个要素类是直接放在工作空问中,还是放在工作空问的一个要素数据集中,这些区别不过逻辑上的,而它们的物理组成都是数据库中的一张二维表,并目表名就是要素类的名字.在一个数据 ...
- infobright系列二:数据迁移
安装之后把之前infobright的数据迁移到新安装的infobright上. 1:挺掉相关的服务 2:scp 把旧数据拷到新安装的infobright上 3:修改/etc/my-ib.cnf的数据目 ...
- React学习笔记一:入门知识概览
一:安装react 1:直接下载react源码包,把需要用到的js文件引入自己的页面即可. 2:BootCDN 的 React CDN 库: 在页面代码中导入即可: <head> < ...
- Java并发容器之CopyOnWriteArraySet与ConcurrentSkipListSet
一:CopyOnWriteArraySet CopyOnWriteArraySet底层其实是通过CopyOnWriteArrayList来实现的,通过组合一个CopyOnWriteArrayList作 ...