JQuery/PHP

FORM表单如何添加验证码(刷新变换)

阿里云

我们在自己做网站时,经常会使用到 FORM 表单,在 FORM 表单中为了防止别人频繁提交,常常会在表单里添加验证码。如下图:

下面介绍一下如何在 FORM 表单如何添加验证码,并且刷新自动变换的效果。

第一步

在网页的 header 标签上面,添加以下的 JS 代码;

也想出现在这里?联系我们
创客主机
  1. <script type="text/javascript">
  2. var code;
  3. function createCode()
  4. {
  5. code = "";
  6. var codeLength = 6; //验证码的长度
  7. var checkCode = document.getElementById("checkCode");
  8. var codeChars = new Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
  9. 'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',
  10. 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'); //所有候选组成验证码的字符,当然也可以用中文的
  11. for(var i = 0; i < codeLength; i++)
  12. {
  13. var charNum = Math.floor(Math.random() * 52);
  14. code += codeChars[charNum];
  15. }
  16. if(checkCode)
  17. {
  18. checkCode.className = "code";
  19. checkCode.innerHTML = code;
  20. }
  21. }
  22. function validateCode()
  23. {
  24. var inputCode=document.getElementById("inputCode").value;
  25. if(inputCode.length <= 0)
  26. {
  27. alert("请输入验证码!");
  28. }
  29. else if(inputCode.toUpperCase() != code.toUpperCase())
  30. {
  31. alert("验证码输入有误!");
  32. createCode();
  33. }
  34. else
  35. {
  36. $('form').submit();
  37. }
  38. }
  39. </script>

第二步

在 FORM 表单的 HTML 代码中,添加以下的 HTML 代码,用于填写验证码和显示验证码;

  1. <form id="form1" runat="server" onsubmit="validateCode()">
  2. <div>
  3. <table border="0" cellspacing="5" cellpadding="5" >
  4. <tr>
  5. <td></td>
  6. <td><div class="code" id="checkCode" onclick="createCode()" ></div></td>
  7. <td><a href="#" onclick="createCode()">看不清换一张</a></td>
  8. </tr>
  9. <tr>
  10. <td>验证码:</td>
  11. <td><input style="float:left;" type="text" id="inputCode" /></td>
  12. <td>请输入验证码</td>
  13. </tr>
  14. <tr>
  15. <td></td>
  16. <td><input id="Button1" onclick="validateCode();" type="button" value="确定" /></td>
  17. <td></td>
  18. </tr>
  19. </table>
  20. </div>
  21. </form>

第三步

为了让网页首次加载时,显示验证码,需要在 BODY 添加一个载入动作;

  1. <body onload="createCode()">

第四步

在 CSS 文件中,添加以下的 CSS 样式,用于控制验证码的样式;

  1. <style type="text/css">
  2. .code
  3. {
  4. background:url(code_bg.jpg);
  5. font-family:Arial;
  6. font-style:italic;
  7. color:blue;
  8. font-size:20px;
  9. border:0;
  10. padding:5px 10px;
  11. letter-spacing:3px;
  12. font-weight:bolder;
  13. cursor:pointer;
  14. width:120px;
  15. height:40px;
  16. line-height:40px;
  17. text-align:center;
  18. vertical-align:middle;
  19. }
  20. </style>

这样就可以在自己的网页中的 FROM 表单中添加了验证码了,并且每刷新一次,就会显示一个新的验证码。

下面是整个验证码代码:

  1. <html>
  2. <head>
  3. <title>js验证码</title>
  4. <style type="text/css">
  5. .code
  6. {
  7. background:url(code_bg.jpg);
  8. font-family:Arial;
  9. font-style:italic;
  10. color:blue;
  11. font-size:20px;
  12. border:0;
  13. padding:5px 10px;
  14. letter-spacing:3px;
  15. font-weight:bolder;
  16. cursor:pointer;
  17. width:120px;
  18. height:40px;
  19. line-height:40px;
  20. text-align:center;
  21. vertical-align:middle;
  22. }
  23. </style>
  24. <script type="text/javascript">
  25. var code;
  26. function createCode()
  27. {
  28. code = "";
  29. var codeLength = 6;
  30. //验证码的长度
  31. var checkCode = document.getElementById("checkCode");
  32. var codeChars = new Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9,
  33. 'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z',
  34. 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z');
  35. //所有候选组成验证码的字符,当然也可以用中文的
  36. for(var i = 0; i < codeLength; i++)
  37. {
  38. var charNum = Math.floor(Math.random() * 52);
  39. code += codeChars[charNum];
  40. }
  41. if(checkCode)
  42. {
  43. checkCode.className = "code";
  44. checkCode.innerHTML = code;
  45. }
  46. }
  47. function validateCode()
  48. {
  49. var inputCode=document.getElementById("inputCode").value;
  50. if(inputCode.length <= 0)
  51. {
  52. alert("请输入验证码!");
  53. }
  54. else if(inputCode.toUpperCase() != code.toUpperCase())
  55. {
  56. alert("验证码输入有误!");
  57. createCode();
  58. }
  59. else
  60. {
  61. $('form').submit();
  62. }
  63. }
  64. </script>
  65. </head>
  66. <body onload="createCode()">
  67. <form id="form1" runat="server" onsubmit="validateCode()">
  68. <div>
  69. <table border="0" cellspacing="5" cellpadding="5" >
  70. <tr>
  71. <td></td>
  72. <td><div class="code" id="checkCode" onclick="createCode()" ></div></td>
  73. <td><a href="#" onclick="createCode()">看不清换一张</a></td>
  74. </tr>
  75. <tr>
  76. <td>验证码:</td>
  77. <td><input style="float:left;" type="text" id="inputCode" /></td>
  78. <td>请输入验证码</td>
  79. </tr>
  80. <tr>
  81. <td></td>
  82. <td><input id="Button1" onclick="validateCode();" type="button" value="确定" /></td>
  83. <td></td>
  84. </tr>
  85. </table>
  86. </div>
  87. </form>
  88. </body>
  89. </html>

FORM 表单如何添加验证码(刷新变换)

已有 251 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!