Ajax和PHP正则表达式验证表单及验证码
模式匹配符:
\:转义字符例如:\b转义了b
^:正则表达式开始符号
$:正则表达式结束符号
*:匹配前面的字符出现0次或者n次
+:匹配前面的字符出现1次或者n次
?:匹配前面的字符出现0次或者1次
.:匹配除了换行符以外的所有单个字符
|:或者的意思,例如x|y匹配x或者y
{n}:匹配前面的n个字符
{n,m}:匹配至少n个最多m个前面字符
[xyz]:匹配中括号里的任意一个字符
[^xyz]:匹配除了中括号里的任意一个字符等价于[0-9]
\w:匹配任意一个数字或字母或下划线等价于[A-Za-z0-9_]
\d:匹配任意一个0--9之间的数字
模式修正符:
i:忽略大小写
常用正则表达式举例:
//用户名由6-18位的字母数字下划线组成,不能由数字开头
varr_name=/^[a-z]\w{5,17}$/i
//密码长度不能少于六位
varr_pwd=/^\w{6,}$/
//所有的通用邮箱地址
varr_eamil=/^\w+@\w+(\.)\w+$/
//匹配一个QQ邮箱地址
//861745122@qq.com
varr_qq_email=/^\d{5,}@qq(\.)com$/
//匹配一个163的邮箱地址
varr_163_email=/^\w+@163(\.)com$/
//匹配一个后缀名可能是.com|.net|.cn|.edu
varemail=/^\w+@\w+(\.)com|net|cn|edu$/
//要求输入有效的年龄段
varr_age=/^\d{1,2}$/
//if(age>=18&&age《=100)
//验证手机号:11位131518开头
varr_tel=/^1[3,5,8]\d{9}$/
//验证身份证号18位或者17位加一个X
varr_s=/^\d{18}|\d{17}x$/i
//验证中文varreg=/^[\u4e00-\u9fa5]{2,17}$/
//php
$reg="/^[\x{4e00}-\x{9fa5}]$/u"
<spanstyle="font-size:24px;">下面是一个例子:</span>
<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml"xml:lang="en">
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=UTF-8"/>
<title></title>
<scripttype="text/javascript"src="public.js"></script>
</head>
<bodyonload="yanzheng(this)">
<formmethod="post"action="info_2.php"onsubmit="returncheck_all()">
<table>
<tr>
<tdcolspan="2">账户基本信息</td>
</tr>
<tr>
<td>登录账号:</td>
<td><inputtype="text"name="zhanghao"onblur="check_zhanghao(this)"><spanname="sp1"></span></td>
</tr>
<tr>
<td>昵称:</td>
<td><inputtype="text"name="nicheng"onblur="check_nicheng(this)"><spanname="sp2"></span></td>
</tr>
<tr>
<td>性别:</td>
<td><inputtype="radio"name="sex"value="男"onclick="check_sex()">男
<inputtype="radio"name="sex"value="女"onclick="check_sex()">女
<spanid="sp3"></span></td>
</tr>
<tr>
<tdcolspan="2">账户安全设置</td>
</tr>
<tr>
<td>登录密码:</td>
<td><inputtype="password"name="pwd"onblur="check_pwd(this)"><spanname="sp4"></span></td>
</tr>
<tr>
<td>确认登录密码:</td>
<td><inputtype="password"name="repwd"onblur="check_repwd(this)"><spanname="sp5"></span></td>
</tr>
<tr>
<td>真实姓名:</td>
<td><inputtype="text"name="username"onblur="check_username(this)"><spanname="sp6"></span></td>
</tr>
<tr>
<td>身份证号:</td>
<td><inputtype="text"name="idcard"onblur="check_idcard(this)"><spanname="sp7"></span></td>
</tr>
<tr>
<td>邮箱地址:</td>
<td><inputtype="text"name="email"onblur="check_email(this)"><spanname="sp8"></span></td>
</tr>
<tr>
<td>验证码</td>
<td><inputtype="text"id="number"onblur="check_number()">
<inputtype="button"onclick="yanzheng()"value="获取验证码">
<spanid="sp10"></span>
<spanid="sp9"></span>
</td>
</tr>
<tr>
<td></td>
<td><inputtype="submit"value="免费注册"></td>
</tr>
</table>
</form>
<scripttype="text/javascript">
//验证登录账号
functioncheck_zhanghao(obj){
varsp1=$('sp1');
if(obj.value==''){
sp1.innerHTML='登录账号不能为空';
sp1.style.color='red';
returnfalse;
}else{
varreg=/^\w{5,10}$/i;
if(reg.test(obj.value)){
sp1.innerHTML='正确';
sp1.style.color='green';
returntrue;
}else{
sp1.innerHTML='登录账号5-10字符';
sp1.style.color='red';
returnfalse;
}
}returntrue;
}
//验证昵称
functioncheck_nicheng(obj){
varsp2=$('sp2');
if(obj.value==''){
sp2.innerHTML='登录账号不能为空';
sp2.style.color='red';
returnfalse;
}else{
varreg=/^\w{5,10}$/i;
if(reg.test(obj.value)){
sp2.innerHTML='正确';
sp2.style.color='green';
returntrue;
}else{
sp2.innerHTML='昵称5-10字符';
sp2.style.color='red';
returnfalse;
}
}returntrue;
}
//验证密码
functioncheck_pwd(obj2){
varsp4=$('sp4');
if(obj2.value==''){
sp4.innerHTML='密码不能为空';
sp4.style.color='red';
returnfalse;
}else{
varreg=/^\w{6,}$/;
if(reg.test(obj2.value)){
sp4.innerHTML='正确';
sp4.style.color='green';
returntrue;
}else{
sp4.innerHTML='格式不正确';
sp4.style.color='red';
returnfalse;
}
}returntrue;
}
//验证确认密码
functioncheck_repwd(obj3){
varsp5=$('sp5');
varpwd=$('pwd');
varrepwd=$('repwd');
if(obj3.value==''){
sp5.innerHTML='密码不能为空';
sp5.style.color='red';
returnfalse;
}else{
if(obj3.value==pwd.value){
sp5.innerHTML='正确';
sp5.style.color='green';
returntrue;
}else{
sp5.innerHTML='确认密码和密码不一致';
sp5.style.color='red';
returnfalse;
}
}returntrue;
}
//验证性别
num2=0;
functioncheck_sex(){
varsex=document.getElementsByName('sex');
//varsp4=document.getElementById('sp4')
for(vari=0;i<sex.length;i++){
if(sex[i].checked==true){
num2=num2+1;
}
}
//alert(num2);
if(num2!=0){
sp3.innerHTML='√';
sp3.style.color='green';
returntrue;
}else{
sp3.innerHTML='性别不能为空';
sp3.style.color='red';
returnfalse;
}
}
//验证姓名
functioncheck_username(obj){
varsp6=$('sp6');
if(obj.value==""){
sp6.innerHTML='用户名不能为空';
sp6.style.color='red';
returnfalse;
}else{
varreg=/^[\u4e00-\u9fa5]{2,3}$/;
if(!reg.test(obj.value)){
sp6.innerHTML='用户名应该2-3个汉字';
sp6.style.color='red';
returnfalse;
}else{
sp6.innerHTML='√';
sp6.style.color='green';
returntrue;
}
}
returntrue;
}
//验证邮箱
functioncheck_email(obj5){
varsp8=$('sp8');
if(obj5.value==''){
sp8.innerHTML='邮箱不能为空';
sp8.style.color='red';
returnfalse;
}else{
varreg=/^(\w+@\w+(\.)com|net|cn)$/;
if(reg.test(obj5.value)){
sp8.innerHTML='正确';
sp8.style.color='green';
returntrue;
}else{
sp8.innerHTML='格式不正确';
sp8.style.color='red';
returnfalse;
}returntrue;
}
}
//验证身份证号
functioncheck_idcard(obj9){
varsp7=$('sp7');
if(obj9.value==''){
sp7.innerHTML='身份证号不能为空';
sp7.style.color='red';
returnfalse;
}else{
varreg=/^\d{18}|\d{17}x$/i;
if(reg.test(obj9.value)){
sp7.innerHTML='正确';
sp7.style.color='green';
returntrue;
}else{
sp7.innerHTML='格式不正确';
sp7.style.color='red';
returnfalse;
}returntrue;
}
}
//生成验证码
functionyanzheng(){
varsp9=document.getElementById('sp9');
varstr1="";
for(vari=1;i<=4;i++){
str1=str1+parseInt(Math.random()*10);
sp9.innerHTML=str1;
}
}
//验证验证码
functioncheck_number(){
varnumber=document.getElementById('number').value
varsp10=document.getElementById('sp10')
varsp9=document.getElementById('sp9');
if(number==""){
sp10.innerHTML='验证码不能为空';
sp10.style.color='red';
returnfalse;
}else{
if(number!=sp9.innerHTML){
sp10.innerHTML='验证码和你写的不一致';
sp10.style.color='red';
returnfalse;
}else{
sp10.innerHTML='√';
sp10.style.color='green';
returntrue;}
returntrue;
}
}
functioncheck_all(){
if(check_zhanghao($('zhanghao'))&check_nicheng($('nicheng'))&check_pwd($('pwd'))&check_repwd($('repwd'))&check_sex()&check_username($('username'))&check_idcard($('idcard'))&check_email($('email'))&check_number()){
returntrue;}
else{returnfalse;}
}
</script>
</body>
</html>
php正则验证
<?php
header("content-type:text/html;charset=utf8");
//var_dump($_POST);die;
//array(5){["uname"]=>string(9)"刘伟超"["uqq"]=>string(10)"1111111111"["uemail"]=>string(12)"66555@qq.com"["utel"]=>string(11)"15863162320"["uinfo"]=>string(48)"地方开始放假开放活动健康的话概括"}
empty($_POST["uname"])?$uname="":$uname=$_POST["uname"];
empty($_POST["uemail"])?$uemail="":$uemail=$_POST["uemail"];
empty($_POST["utel"])?$utel="":$utel=$_POST["utel"];
empty($_POST["uqq"])?$uqq="":$uqq=$_POST["uqq"];
empty($_POST["uinfo"])?$uinfo="":$uinfo=$_POST["uinfo"];
//验证姓名
$reg="/^[\x{4e00}-\x{9fa5}]{2,3}$/u";
if(!preg_match($reg,$uname)){
echo"用户名应该2-3个汉字";die;
//header("refresh:1;url=form.html");
}
//验证邮箱
$reg="/^(\w+@\w+(\.)com|net|cn)$/";
if(!preg_match($reg,$uemail)){
echo"邮箱必须含有@,且以com结尾";header("refresh:1;url=form.html");die;
}
//验证座机号
$reg="/^\d{11}$/";
if(!preg_match($reg,$utel)){
echo"座机号以010-22222222格式";header("refresh:1;url=form.html");die;
}
//验证QQ号
$reg="/^\d{5,11}$/";
if(!preg_match($reg,$uqq)){
echo"qq必须是5-11位纯数字";header("refresh:1;url=form.html");die;
}
//验证简介
/*$reg="/^[\x{4e00}-\x{9fa5}]{10,100}\W+/u";
if(!preg_match($reg,$uinfo)){
echo"简介应该10-100个汉字";die;
//header("refresh:1;url=form.html");
}
*/
//连接数据库
$link=mysql_connect('127.0.0.1','root','root')ordie("连接失败");
//选择数据库
mysql_select_db('kaoshi',$link);
//设置字符集
mysql_query("setnamesutf8");
//写sql语句
$sql="insertintozhuce(c_name,c_qq,c_email,c_tel,c_info)values('$uname','$uqq','$uemail','$utel','$uinfo')";
//echo$sql;die;
$rel=mysql_query($sql);
if($rel){
echo"注册成功";header("refresh:1;url=show.php");
}else{echo"注册失败";header("refresh:1;url=form.html");}
?>
以上所述是小编给大家介绍的Ajax和PHP正则表达式验证表单及验证码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!