JavaScript生成隨機驗證碼代碼實例
利用canvas制作一個隨機驗證碼:
1、clearRect:context.clearRect(x,y,width,height);清空給定矩形內(nèi)的指定像素
2、fillStyle:設(shè)置畫筆的顏色
3、rotate(deg):旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 )
4、translate(): 方法重新映射畫布上的位置
5、Math.random():獲取0-1之間的一個隨機數(shù),不包含1

<!-- HTML -->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>canvas隨機驗證碼</title>
</head>
<body>
<canvas id="canvas" width="100" height="40" style="border: 1px solid red;display: block;margin: 0 auto;"></canvas>
</body>
<script type="text/javascript">
var myCanvas = document.querySelector("#canvas");
var blur = myCanvas.getContext("2d");
// 當(dāng)點擊畫布時創(chuàng)建一個新的路徑
// 驗證碼封裝
myCanvas.onclick = function() {
// 實現(xiàn)點擊畫布創(chuàng)建一個新的驗證碼
blur.clearRect(0,0,100,40);
verify();
}
verify();
function verify() {
// 繪制矩形框
// blur.strokeRect(0,0,100,40);
// 隨機驗證碼
var arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "s", "t", "u",
"v", "w", "x", "y", "z", "A", "B", "C", "D", "F", "G", "H", "I", "J", "K", "L", "S", "T", "U", "V", "W", "X", "Y",
"Z"
];
// 顯示四位數(shù)的驗證碼
for (var i = 0; i < 4; i++) {
var x = 20 + 20 * i;
var y = 20 + 10 * Math.random();
// console.log(x,y);
// 在數(shù)組中獲取到隨機的索引整數(shù)
var index = Math.floor(Math.random() * arr.length);
// 通過隨機的索引獲取到隨機的元素
var texts = arr[index];
// 設(shè)置驗證碼的相關(guān)樣式
blur.font = "bold 20px 微軟雅黑";
blur.fillStyle = textColor();
// 畫布旋轉(zhuǎn)顯示
// translate() 方法重新映射畫布上的位置
blur.translate(x, y);
// 將畫布旋轉(zhuǎn),旋轉(zhuǎn)角度,以弧度旋轉(zhuǎn)(弧度=degrees*Math.PI/180 )
var deg = 90 * Math.random() * Math.PI / 180;
blur.rotate(deg); //
blur.fillText(texts, 0, 0);
// 將畫布映射返回原來的位置
blur.rotate(-deg);
blur.translate(-x, -y);
}
// 制作驗證碼的干擾線制作
for(var i=0;i<6;i++){
blur.beginPath();
blur.moveTo(Math.random()*100,Math.random()*40);
blur.lineTo(Math.random()*100,Math.random()*40);
// 設(shè)置干擾線的顏色
blur.strokeStyle=textColor();
blur.stroke();
}
// 制作驗證碼的干擾圓點
for(var i=0;i<20;i++){
blur.beginPath();
var x=Math.random()*100;
var y=Math.random()*100;
blur.moveTo(x,y);
blur.lineTo(x+1,y+1);
// 設(shè)置干擾線的顏色
blur.strokeStyle=textColor();
blur.stroke();
}
}
// 獲取隨機顏色封裝
function textColor(){
var red=Math.floor(Math.random()*256);
var green=Math.floor(Math.random()*256);
var blue=Math.floor(Math.random()*256);
return "rgb("+red+","+green+","+blue+")";
}
</script>
</html>
| x | 要清除的矩形左上角的 x 坐標(biāo) |
| y | 要清除的矩形左上角的 y 坐標(biāo) |
| width | 要清除的矩形的寬度,以像素計 |
| height | 要清除的矩形的高度,以像素計 |
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript使用location.search的示例
本文介紹javascript 使用location.search獲取當(dāng)前地址欄參數(shù)的實例2013-11-11

