原生javascript 制作canvas 验证码

时间:2023-03-10 07:43:30
原生javascript 制作canvas  验证码
<canvas id="canvas" width="" height=""></canvas>
<a href="#" id="changeImg">看不清,换一张</a>
<script>
/**生成一个随机数**/
function randomNum(min, max) {
return Math.floor(Math.random() * (max - min) + min);
}
/**生成一个随机色**/
function randomColor(min, max) {
var r = randomNum(min, max);
var g = randomNum(min, max);
var b = randomNum(min, max);
return "rgb(" + r + "," + g + "," + b + ")";
}
drawPic();
document.getElementById("changeImg").onclick = function(e) {
e.preventDefault();
drawPic();
} /**绘制验证码图片**/
function drawPic() {
var canvas = document.getElementById("canvas");
var width = canvas.width;
var height = canvas.height;
var ctx = canvas.getContext('2d');
ctx.textBaseline = 'bottom'; //文本对齐方式 /**绘制背景色**/
ctx.fillStyle = randomColor(, ); //颜色若太深可能导致看不清
ctx.fillRect(, , width, height);
/**绘制文字**/
var str = 'ABCEFGHIJKLMNOPQRSTUVWXYZ123456789';
for(var i = ; i < ; i++) {
var txt = str[randomNum(, str.length)];
ctx.fillStyle = randomColor(, ); //随机生成字体颜色
ctx.font = randomNum(, ) + 'px SimHei'; //随机生成字体大小
var x = + i * ;
var y = randomNum(, );
var deg = randomNum(-, );
//修改坐标原点和旋转角度
ctx.translate(x, y);
ctx.rotate(deg * Math.PI / );
ctx.fillText(txt, , );
//恢复坐标原点和旋转角度
ctx.rotate(-deg * Math.PI / );
ctx.translate(-x, -y);
}
/**绘制干扰线**/
for(var i = ; i < ; i++) {
ctx.strokeStyle = randomColor(, );
ctx.beginPath();
ctx.moveTo(randomNum(, width), randomNum(, height));
ctx.lineTo(randomNum(, width), randomNum(, height));
ctx.stroke();
}
/**绘制干扰点**/
for(var i = ; i < ; i++) {
ctx.fillStyle = randomColor(, );
ctx.beginPath();
ctx.arc(randomNum(, width), randomNum(, height), , , * Math.PI);
ctx.fill();
}
}
</script>

网上好多都是插件,希望这个对你们有用。谢谢。