码迷,mamicode.com
首页 > 其他好文 > 详细

相关登录随机验证码公共函数

时间:2017-08-18 23:39:13      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:etc   and   20px   随机验证码   pat   mat   更换   val   event   

function randomCode(){
function rand(){
var str="abcdefghijklmnopqrstuvwxyz0123456789";
var arr=str.split("");
var validate="";
var ranNum;
for(var i=0;i<4;i++){
ranNum=Math.floor(Math.random()*36); //随机数在[0,35]之间
validate+=arr[ranNum];
}
return validate;
}

/*干扰线的随机x坐标值*/
function lineX(){
var ranLineX=Math.floor(Math.random()*90);
return ranLineX;
}

/*干扰线的随机y坐标值*/
function lineY(){
var ranLineY=Math.floor(Math.random()*40);
return ranLineY;
}

function clickChange(){
var mycanvas=document.getElementById(‘mycanvas‘);
var cxt=mycanvas.getContext(‘2d‘);
cxt.fillStyle=‘#000‘;
cxt.fillRect(0,0,90,40);

/*生成干扰线20条*/
for(var j=0;j<20;j++){
cxt.strokeStyle=‘#fff‘;
cxt.beginPath(); //若省略beginPath,则每点击一次验证码会累积干扰线的条数
cxt.moveTo(lineX(),lineY());
cxt.lineTo(lineX(),lineY());
cxt.lineWidth=0.5;
cxt.closePath();
cxt.stroke();
}
cxt.fillStyle=‘red‘;
cxt.font=‘bold 20px Arial‘;
cxt.fillText(rand(),25,25); //把rand()生成的随机数文本填充到canvas中
}
clickChange();
/*点击验证码更换*/
var mycanvas=document.querySelector(‘canvas‘);
mycanvas.onclick=function(e){
e.preventDefault(); //阻止鼠标点击发生默认的行为
clickChange();
};

}

相关登录随机验证码公共函数

标签:etc   and   20px   随机验证码   pat   mat   更换   val   event   

原文地址:http://www.cnblogs.com/supreme-H/p/7392538.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!