javascript验证码

 转贴自《java综合网》

将下文代码保存成html页面即可查看效果

  1. <HTML>
  2.     <HEAD>
  3.         <TITLE>javascript验证码</TITLE>
  4.         <META NAME="Description" CONTENT="javascript验证码,验证输入密码的强弱">
  5.         <script type="text/javascript">
  6.             var agt = navigator.userAgent.toLowerCase();
  7.             var is_op = (agt.indexOf("opera") != -1);
  8.             var is_ie = (agt.indexOf("msie") != -1) && document.all && !is_op;
  9.             var is_ie5 = (agt.indexOf("msie 5") != -1) && document.all && !is_op;
  10.    
  11.             function CreateXmlHttpReq(handler) {
  12.                 var xmlhttp = null;
  13.                 if (is_ie) {
  14.                     var control = (is_ie5) ? "Microsoft.XMLHTTP" : "Msxml2.XMLHTTP";
  15.                     try {
  16.                         xmlhttp = new ActiveXObject(control);
  17.                         xmlhttp.onreadystatechange = handler;
  18.                     } catch (ex) {
  19.                         alert("You need to enable active scripting and activeX controls");  
  20.                     }
  21.   
  22.                 } else {
  23.                     xmlhttp = new XMLHttpRequest();
  24.                     xmlhttp.onload = handler;
  25.                     xmlhttp.onerror = handler;
  26.                 }
  27.                 return xmlhttp;
  28.             }
  29.   
  30.             function XmlHttpPOST(xmlhttp, url, data) {
  31.                 try {
  32.                     xmlhttp.open("POST", url, true);
  33.                     xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
  34.                     xmlhttp.send(data);
  35.                 } catch (ex) {}
  36.             }
  37.             var myxmlhttp;
  38.             ratingMsgs = new Array(6);
  39.             ratingMsgColors = new Array(6);
  40.             barColors = new Array(6);
  41.   
  42.             ratingMsgs[0] = "太短";
  43.             ratingMsgs[1] = "弱";
  44.             ratingMsgs[2] = "一般";
  45.             ratingMsgs[3] = "很好";
  46.             ratingMsgs[4] = "极佳";
  47.             ratingMsgs[5] = "未评级";
  48.   
  49.             ratingMsgColors[0] = "#676767";
  50.             ratingMsgColors[1] = "#aa0033";
  51.             ratingMsgColors[2] = "#f5ac00";
  52.             ratingMsgColors[3] = "#6699cc";
  53.             ratingMsgColors[4] = "#008000";
  54.             ratingMsgColors[5] = "#676767";
  55.   
  56.             barColors[0] = "#dddddd";
  57.             barColors[1] = "#aa0033";
  58.             barColors[2] = "#ffcc33";
  59.             barColors[3] = "#6699cc";
  60.             barColors[4] = "#008000";
  61.             barColors[5] = "#676767";
  62.   
  63.             function CreateRatePasswdReq () {
  64.                 var passwd = getElement('Passwd').value;
  65.                 var email = getElement('Email').value;
  66.                 var lastname = getElement('LastName').value;
  67.                 var firstname = getElement('FirstName').value;
  68.                 var min_passwd_len = 6;
  69.                 if (passwd.length < min_passwd_len) {
  70.                     if (passwd.length > 0) {
  71.                         DrawBar(0);
  72.                     } else {
  73.                         ResetBar();
  74.                     }
  75.                 }else {
  76.                     passwd = escape(passwd);
  77.                     var params = 'Passwd='+passwd+'Email='+email+'FirstName='+firstname+'LastName='+lastname;
  78.                     myxmlhttp = CreateXmlHttpReq(RatePasswdXmlHttpHandler);
  79.                     XmlHttpPOST(myxmlhttp, "https://www.google.com/accounts/RatePassword", params);
  80.                 }
  81.             }
  82.             function getElement(name) {
  83.                 if (document.all) {
  84.                     return document.all(name);
  85.                 }
  86.                 return document.getElementById(name);
  87.             }
  88.             function RatePasswdXmlHttpHandler() { 
  89.                 if (myxmlhttp.readyState != 4) {
  90.                     return;
  91.                 }
  92.                 rating = parseInt(myxmlhttp.responseText);
  93.                 DrawBar(rating);
  94.             }
  95.             function DrawBar(rating) {
  96.                 var posbar = getElement('posBar');
  97.                 var negbar = getElement('negBar');
  98.                 var passwdRating = getElement('passwdRating');
  99.                 var barLength = getElement('passwdBar').width;
  100.                 if (rating >= 0 && rating <= 4) {
  101.                     posbar.style.width = barLength / 4 * rating + "px";
  102.                     negbar.style.width = barLength / 4 * (4 - rating) + "px";
  103.                 }else {
  104.                     posbar.style.width = "0px";
  105.                     negbar.style.width = barLength + "px";
  106.                     rating = 5;
  107.                 }
  108.                 posbar.style.background = barColors[rating]
  109.                 passwdRating.innerHTML = "<font color='" + ratingMsgColors[rating] +"'>" + ratingMsgs[rating] + "</font>";
  110.             }
  111.             function ResetBar() {
  112.                 var posbar = getElement('posBar');
  113.                 var negbar = getElement('negBar');
  114.                 var passwdRating = getElement('passwdRating');
  115.                 var barLength = getElement('passwdBar').width;
  116.                 posbar.style.width = "0px";
  117.                 negbar.style.width = barLength + "px";
  118.                 passwdRating.innerHTML = "";
  119.             }
  120.         </script>
  121.     </HEAD>
  122.     <BODY>
  123.         <table width="60%" border="0">
  124.             <tr>
  125.                 <td width="30%">
  126.                     <input type="hidden" value="" id="FirstName" size="30">
  127.                     <input type="hidden" value="" id="LastName" size="30">
  128.                     <input type="hidden" id="Email" value="" size="30">
  129.                     <input type="password" id="Passwd" value=""
  130.                         onkeyup="CreateRatePasswdReq()" size="30">
  131.                 </td>
  132.                 <td width="70%">
  133.                     <table cellpadding="0" cellspacing="0" border="0">
  134.                         <tr>
  135.                             <td width="200" id="passwdBar">
  136.                                 <table cellpadding="0" cellspacing="0" border="0">
  137.                                     <tr>
  138.                                         <td nowrap valign="top" height="15px">
  139.                                             <font color="#808080" size="-1" face="Arial, sans-serif"><div
  140.                                                     id="passwdRating"></div> </font>
  141.                                         </td>
  142.                                     </tr>
  143.                                     <tr>
  144.                                         <td height="3px"></td>
  145.                                     </tr>
  146.                                     <tr>
  147.                                         <td colspan="2">
  148.                                             <table cellpadding="0" bgcolor="#ffffff" cellspacing="0"
  149.                                                 border="0" width="200">
  150.                                                 <tr>
  151.                                                     <td width="0%" id="posBar" bgcolor="#e0e0e0" height="4px"></td>
  152.                                                     <td width="100%" id="negBar" bgcolor="#e0e0e0" height="4px"></td>
  153.                                                 </tr>
  154.                                             </table>
  155.                                         </td>
  156.                                     </tr>
  157.                                 </table>
  158.                             </td>
  159.                         </tr>
  160.                     </table>
  161.                 </td>
  162.             </tr>
  163.         </table>
  164.     </BODY>
  165. </HTML>

 

效果如下图:

1、原始状态:

2、输入少于六个的字符:

3、输入六个及以上的纯阿拉伯数字:

4、输入简单组合的数字与字母组合:

5、输入复杂的数字、字母等:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值