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的更多相关文章

  1. formValidator 表单验证

    作为一名程序员,在解决工作中遇到问题之后,做一些总结是有必要的,既方便总结温习相关知识点,也为广大的程序员提供了一些工作经历,给予同行一面明鉴. 首先,众所周知的,我们需要引用js类库: eg:< ...

  2. formValidator表单验证示例

    <script type="text/javascript">$(document).ready(function(){ $.formValidator.initCon ...

  3. 表单验证插件 - formValidator

    表单验证插件 - formValidator * 引入formValidator插件文件 * 引入formValidator插件的主文件 * 引入formValidator插件的正则有关文件 * 引入 ...

  4. 超级强大的formValidator

    来源: http://www.cnblogs.com/wzmaodong http://www.neatstudio.com/show-73-1.shtml  (全) http://www.cnblo ...

  5. formValidator的一些验证实例

    原帖地址:http://www.cnblogs.com/talk/archive/2012/01/29/2330887.html $(function () { try { $.formValidat ...

  6. jquery表单验证使用插件formValidator

    JQuery表单验证使用插件formValidator 作者: 字体:[增加 减小] 类型:转载 时间:2012-11-10我要评论 jquery表单验证使用插件formValidator,可供有需求 ...

  7. jQuery formValidator手册

    什么是jQuery formValidator? jQuery formValidator表单验证插件是客户端表单验证插件. 在做B/S开发的时候,我们经常涉及到很多表单验证,例如新用户注册,填写个人 ...

  8. jQuery formValidator使用入门

    使用插件必须加载的文件 //加载jQuery类库 <script type="text/javascript" src="jquery-1.7.1.min.js&q ...

  9. 基于jquery的表单校验插件 - formvalidator使用体验

    下载地址:http://www.formvalidator.net/ 基本样例 <form action="/registration" method="POST& ...

  10. jQuery formValidator表单验证插件常见问题

    1.    如何实现一个控件,根据不同的情况,实现不同的控制? 2.    一个页面上我有几个tab页,如何实现每个Tab页上的控件单独校验? 3.    我采用的页面上文字问题的方式,点提交的时候, ...

随机推荐

  1. ASPNETPager常用属性

    <webdiyer:AspNetPager ID="pager" runat="server" class="page" FirstP ...

  2. 写手Remoting测试工具

    基于.NET开发分布式系统.经经常使用到Remoting技术.在測试驱动开发流行的今天.假设针对分布式系统中的每一个Remoting接口的每一个方法都要写具体的測试脚本,无疑很浪费时间.所以,我想写一 ...

  3. 【SICP练习】150 练习4.6

    练习4-6 原版的 Exercise 4.6. Let expressions are derived expressions, because (let (( ) - ( )) ) is equiv ...

  4. hdu 质方数

    Problem Description   小明天生对数字比较敏感,3岁的时候就能背诵圆周率一百位. 现在,小明慢慢长大了,但依然很喜欢数字,最近,他迷上了质数和平方数,并且自己把质数的平方命名为“质 ...

  5. hdu Word Amalgamation(map)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1113 找单词 #include <iostream> #include <strin ...

  6. oracle_根据表名拼装语句

    1.-----批量删除用户下所有表数据------保留表结构 eg: 批量删除用户下的所有表数据 SELECT 'TRUNCATE TALBE '||TABLE_NAME||';' FROM USER ...

  7. 【百度地图API】交你如何用百度地图搜索自己的数据!不需数据库!

    原文:[百度地图API]交你如何用百度地图搜索自己的数据!不需数据库! 摘要: 我有一定的房产数据,还有银行数据.我想在百度地图上标注出来,并且能搜索到我这些数据. 可是百度的数据库上并没有我的数据. ...

  8. js 正则之 控制字符 \cX

    原文:js 正则之 控制字符 \cX 前些天在司徒正美的群里有人问了这么个问题:正则表达式里特殊字符 \cX 到底是什么?确实,我之前也挺在意的,但是一直没去看到底是什么.在MDN上只说是控制字符(详 ...

  9. Mvc 6 中创建 Web Api

    如何在Mvc 6 中创建 Web Api以及如何脱离IIS实现自我托管 微软推出的Asp.net vNext(asp.net 5.0)的其中的一个目标就是统一mvc 和web api 的框架.接下来我 ...

  10. Cts分析框架(4)-添加任务

    Debug watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaXRmb290YmFsbA==/font/5a6L5L2T/fontsize/400/fill/ ...