JS验证码生成(入门级别)

Posted superdrew

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS验证码生成(入门级别)相关的知识,希望对你有一定的参考价值。

练手项目:JavaScript验证码

 1 <!DOCTYPE html>
 2 <html>
 3 
 4     <head>
 5         <meta charset="UTF-8">
 6         <title></title>
 7         <style>
 8             #mycanvas {
 9                 cursor: pointer;
10             }
11         </style>
12     </head>
13 <!--值得优化的地方:①干扰线的随机颜色;②可以加点干扰点-->
14     <body>
15         <canvas id="mycanvas" width=\'90\' height=\'40\'>
16             您的浏览器不支持canvas,请换个浏览器试试~
17         </canvas>
18     </body>
19 
20     <script>
21         /*生成4位随机数*/
22         function rand() {
23             var str = "abcdefghijklmnopqrstuvwxyz0123456789";
24             var arr = str.split("");
25             var validate = "";
26             var ranNum;
27             for(var i = 0; i < 4; i++) {
28                 ranNum = Math.floor(Math.random() * 36); //随机数在[0,35]之间
29                 validate += arr[ranNum];
30             }
31             return validate;
32         }
33 
34         /*干扰线的随机x坐标值*/
35         function lineX() {
36             var ranLineX = Math.floor(Math.random() * 90);
37             return ranLineX;
38         }
39 
40         /*干扰线的随机y坐标值*/
41         function lineY() {
42             var ranLineY = Math.floor(Math.random() * 40);
43             return ranLineY;
44         }
45 
46         function clickChange() {
47             var mycanvas = document.getElementById(\'mycanvas\');
48             var cxt = mycanvas.getContext(\'2d\');
49             cxt.fillStyle = \'#000\';
50             cxt.fillRect(0, 0, 90, 40);
51 
52             /*生成干扰线20条*/
53             for(var j = 0; j < 30; j++) {
54                 cxt.strokeStyle = \'#fff\';
55                 cxt.beginPath(); //若省略beginPath,则每点击一次验证码会累积干扰线的条数
56                 cxt.moveTo(lineX(), lineY());
57                 cxt.lineTo(lineX(), lineY());
58                 cxt.lineWidth = 0.5;
59                 cxt.closePath();
60                 cxt.stroke();
61             }
62 
63             cxt.fillStyle = \'yellow\';
64             cxt.font = \'bold 20px Arial\';
65             cxt.fillText(rand(), 30, 30); //把rand()生成的随机数文本填充到canvas中      
66         }
67 
68         clickChange();
69 
70         /*点击验证码更换*/
71         mycanvas.onclick = function(e) {
72             e.preventDefault(); //阻止鼠标点击发生默认的行为
73             clickChange();
74         };
75     </script>
76 
77 </html>

结果显示截图:

 

以上是关于JS验证码生成(入门级别)的主要内容,如果未能解决你的问题,请参考以下文章

node.js生成验证码及图片

js生成图片验证码

生成登录页验证码

JSP 设计教师与学生不同登陆界面(带验证码)

PHP实现随机生成验证码功能

使用canvas及js简单生成验证码方法