当前位置: 首页 > 编程日记 > 正文

顯示密碼安全性強度

None.gif<div class="from-nav">
None.gif                        
<div class="Mtitle"><span>密码:</span></div>
None.gif                        
<div class="Mright"><input name="password" type="password" id="password" size="20" class="colorblue" onfocus="this.className='colorfocus';" onblur="this.className='colorblue';" onkeyup="return loadinputcontext(this);" /><span>不得少于6个字符</span>
None.gif                        
</div>
None.gif
    </div>
None.gif
    <div class="from-nav">
None.gif                        
<div class="Mtitle"><span>密码强度:</span></div>
None.gif                        
<div class="Mright">
None.gif
<script type="text/javascript">
ExpandedBlockStart.gifContractedBlock.gif        
var PasswordStrength =dot.gif{
InBlock.gif            Level : [
"极佳","一般","较弱","太短"],
InBlock.gif            LevelValue : [
15,10,5,0],//强度值
InBlock.gif
            Factor : [1,2,5],//字符加数,分别为字母,数字,其它
InBlock.gif
            KindFactor : [0,0,10,20],//密码含几种组成的加数 
InBlock.gif
            Regex : [/[a-zA-Z]/g,/\d/g,/[^a-zA-Z0-9]/g] //字符正则数字正则其它正则
ExpandedBlockEnd.gif
            }

None.gif        PasswordStrength.StrengthValue 
= function(pwd)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
var strengthValue = 0;
InBlock.gif            
var ComposedKind = 0;
InBlock.gif            
for(var i = 0 ; i < this.Regex.length;i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
var chars = pwd.match(this.Regex[i]);
InBlock.gif                
if(chars != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    strengthValue 
+= chars.length * this.Factor[i];
InBlock.gif                    ComposedKind 
++;
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            strengthValue 
+= this.KindFactor[ComposedKind];
InBlock.gif            
return strengthValue;
ExpandedBlockEnd.gif        }
 
None.gif        PasswordStrength.StrengthLevel 
= function(pwd)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
var value = this.StrengthValue(pwd);
InBlock.gif            
for(var i = 0 ; i < this.LevelValue.length ; i ++)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
if(value >= this.LevelValue[i] )
InBlock.gif                    
return this.Level[i];
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }

None.gif        
function loadinputcontext(o)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif           
var showmsg=PasswordStrength.StrengthLevel(o.value);
InBlock.gif           
switch(showmsg)
ExpandedSubBlockStart.gifContractedSubBlock.gif           
dot.gif{
InBlock.gif              
case "太短": showmsg+=" <img src='images/level/1.gif' width='88' height='11' />";break;
InBlock.gif              
case "较弱": showmsg+=" <img src='images/level/2.gif' width='88' height='11' />";break;
InBlock.gif              
case "一般": showmsg+=" <img src='images/level/3.gif' width='88' height='11' />";break;
InBlock.gif              
case "极佳": showmsg+=" <img src='images/level/4.gif' width='88' height='11' />";break;
ExpandedSubBlockEnd.gif           }

InBlock.gif           document.getElementById(
'showmsg').innerHTML = showmsg;
ExpandedBlockEnd.gif        }

None.gif        
function htmlEncode(source, display, tabs)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
function special(source)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
var result = '';
InBlock.gif                
for (var i = 0; i < source.length; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
var c = source.charAt(i);
InBlock.gif                    
if (c < ' ' || c > '~')
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        c 
= '&#' + c.charCodeAt() + ';';
ExpandedSubBlockEnd.gif                    }

InBlock.gif                    result 
+= c;
ExpandedSubBlockEnd.gif                }

InBlock.gif                
return result;
ExpandedSubBlockEnd.gif            }

InBlock.gif            
function format(source)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
// Use only integer part of tabs, and default to 4
InBlock.gif
                tabs = (tabs >= 0? Math.floor(tabs) : 4;
InBlock.gif                
// split along line breaks
InBlock.gif
                var lines = source.split(/\r\n|\r|\n/);
InBlock.gif                
// expand tabs
InBlock.gif
                for (var i = 0; i < lines.length; i++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
var line = lines[i];
InBlock.gif                    
var newLine = '';
InBlock.gif                    
for (var p = 0; p < line.length; p++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        
var c = line.charAt(p);
InBlock.gif                        
if (c === '\t')
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            
var spaces = tabs - (newLine.length % tabs);
InBlock.gif                            
for (var s = 0; s < spaces; s++)
ExpandedSubBlockStart.gifContractedSubBlock.gif                            
dot.gif{
InBlock.gif                                newLine 
+= ' ';
ExpandedSubBlockEnd.gif                            }

ExpandedSubBlockEnd.gif                        }

InBlock.gif                        
else
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            newLine 
+= c;
ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }

InBlock.gif                    
// If a line starts or ends with a space, it evaporates in html
InBlock.gif
                    // unless it's an nbsp.
InBlock.gif
                    newLine = newLine.replace(/(^ )|( $)/g, '&nbsp;');
InBlock.gif                    lines[i] 
= newLine;
ExpandedSubBlockEnd.gif                }

InBlock.gif                
// re-join lines
InBlock.gif
                var result = lines.join('<br />');
InBlock.gif                
// break up contiguous blocks of spaces with non-breaking spaces
InBlock.gif
                result = result.replace(/  /g, ' &nbsp;');
InBlock.gif
                // tada!
InBlock.gif
                return result;
ExpandedSubBlockEnd.gif            }

InBlock.gif            
var result = source;
InBlock.gif            
// ampersands (&)
InBlock.gif
            result = result.replace(/\&/g,'&amp;');
InBlock.gif            
// less-thans (<)
InBlock.gif
            result = result.replace(/\</g,'&lt;');
InBlock.gif            
// greater-thans (>)
InBlock.gif
            result = result.replace(/\>/g,'&gt;');
InBlock.gif            
if (display)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
// format for display
InBlock.gif
                result = format(result);
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
// Replace quotes if it isn't for display,
InBlock.gif
                // since it's probably going in an html attribute.
InBlock.gif
                result = result.replace(new RegExp('"','g'), '&quot;');
ExpandedSubBlockEnd.gif            }

InBlock.gif            
// special characters
InBlock.gif
            result = special(result);
InBlock.gif            
// tada!
InBlock.gif
            return result;
ExpandedBlockEnd.gif        }

None.gif        
var profile_username_toolong = '对不起,您的用户名超过 20 个字符,请输入一个较短的用户名。';
None.gif        
var profile_username_tooshort = '对不起,您输入的用户名小于3个字符, 请输入一个较长的用户名。';
None.gif        
var profile_username_pass = "可用";
None.gif        
function checkusername(username)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
var unlen = username.replace(/[^\x00-\xff]/g, "**").length;
ExpandedSubBlockStart.gifContractedSubBlock.gif            
if(unlen < 3 || unlen > 20dot.gif{
InBlock.gif                document.getElementById(
"checkresult").innerHTML = "<font color='#009900'>" + (unlen < 3 ? profile_username_tooshort : profile_username_toolong) + "</font>";
InBlock.gif                
return;
ExpandedSubBlockEnd.gif            }

InBlock.gif            ajaxRead(
"tools/ajax.aspx?t=checkusername&username=" + escape(username), "showcheckresult(obj,'" + username + "');");
ExpandedBlockEnd.gif        }

None.gif        
function showcheckresult(obj, username)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif{
InBlock.gif            
var res = obj.getElementsByTagName('result');
InBlock.gif            
var resContainer = document.getElementById("checkresult");
InBlock.gif            
var result = "";
InBlock.gif            
if (res[0!= null && res[0!= undefined)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif                
if (res[0].childNodes.length > 1dot.gif{
InBlock.gif                    result 
= res[0].childNodes[1].nodeValue;
ExpandedSubBlockStart.gifContractedSubBlock.gif                }
 else dot.gif{
InBlock.gif                    result 
= res[0].firstChild.nodeValue;            
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            
if (result == "1")
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                resContainer.innerHTML 
= "<font color='#009900'>对不起,您输入的用户名 \"" + htmlEncode(username, true, 4) + "\" 已经被他人使用或被禁用,请选择其他名字后再试。</font>";
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                resContainer.innerHTML 
= profile_username_pass;
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }

None.gif
</script>
None.gif
<script type="text/javascript" src="templates/default/ajax.js"></script>
None.gif
             <span id="showmsg"></span>
None.gif
                </div>
None.gif
    </div>

转载于:https://www.cnblogs.com/Nina-piaoye/archive/2008/02/18/1071866.html

相关文章:

HashMap集合遍历的五种方式

文章目录创建HashMap集合&#xff0c;添加数据一、第一种foreach遍历二、第二种foreach遍历三、第一种迭代器遍历 效率高&#xff08;建议使用&#xff09;四、第二种迭代器遍历 效率低&#xff08;不建议使用&#xff09;五、JDK8新特性&#xff0c;通过lambda遍历Map创建Hash…

JAVA核心技术I---JAVA基础知识(查漏补缺private,static)

一&#xff1a;private对于类和对象&#xff08;同C&#xff09; private是只有这个类内部可以访问&#xff08;类的成员函数和定义初始化&#xff09; private是类之间的限制&#xff0c;而不是对对象的限制《重点》 同类对象是可以直接访问对象的私有成员 class priTest{priv…

『TensorFlow』命令行参数解析

argparse很强大&#xff0c;但是我们未必需要使用这么繁杂的东西&#xff0c;TensorFlow自己封装了一个简化版本的解析方式&#xff0c;实际上是对argparse的封装 脚本化调用tensorflow的标准范式&#xff1a; import pprint import tensorflow as tfflags tf.app.flags# 脚本…

IIS重起批处理

将以下代码保存到一个BAT文件中,执行后便可释放所有被锁定的组件。执行顺序是&#xff1a;停止&#xff37;&#xff37;&#xff37;服务&#xff0d;〉停止组件保护&#xff0d;〉开启组件保护&#xff0d;〉开启&#xff37;&#xff37;&#xff37;服务。net stop w3svc /…

RenderTree渲染树

RenderTree渲染树对类中的静态成员有很重要的关系&#xff0c;这个和多态是有很重要的关系&#xff0c;举个简单的例子&#xff0c;在游戏中&#xff0c;马里奥需要渲染&#xff0c;蘑菇也需要渲染&#xff0c;怪兽也需要渲染&#xff0c;其是串在一个树上的&#xff0c;但是不…

JAVA IO流复制文件夹及里面的所有文件

public static void main(String[] args) throws Exception {//复制到哪个路径&#xff08;path&#xff09;中String path "E:\\main";File file new File("F:\\main");copyAll(file, path);}public static void copy(File file, String path) throws E…

python RSA 加密与签名

PyCrypto装起来就简单多了&#xff0c;我是直接 sudo easy_install pycrypto 直接搞定的先生成rsa的公私钥&#xff1a;打开控制台&#xff0c;输入 openssl 再输入 genrsa -out private.pem 1024 来生成私钥接着输入 rsa -in private.pem -pubout -out public.pem 来生成公钥$…

深度解析VC中的消息(上)

消息是指什么&#xff1f;消息系统对于一个win32程序来说十分重要&#xff0c;它是一个程序运行的动力源泉。一个消息&#xff0c;是系统定义的一个32位的值&#xff0c;他唯一的定义了一个事件&#xff0c;向Windows发出一个通知&#xff0c;告诉应用程序某个事情发生了。例如…

漫谈C#之关键字(1)

每一种语言都有非常多的关键字&#xff0c;而且这些关键字也都大同小异&#xff0c;不过毕竟还是有些许的不一样。有些关键字大家碰到的多了&#xff0c;自然就熟悉了&#xff0c;但是有些关键字用得不大多&#xff0c;或者是新引入的&#xff0c;所以就不大熟悉了。我平常在用…

Python-CSS整理

CSS层叠样式表 1.格式 h1 {name:abc&#xff0c;color:red}&#xff1b; 选择器-属性-值 2.ID和类选择 #ID .类 3.CSS引用方式 link文件-外部样式表 script style-内部样式表 标签 style-内联样式 4.background背景 ~background ~-color 背景颜色 ~-repeat 是否重复 ~-pos…

利用 socket 获取 tcp 包并解析的问题。

服务器端代码如下&#xff1a;&#xff08;Java Servlet 实现&#xff09; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { OutputStream out response.getOutputStream(); try { …

Mysql排序后显示排序序号

网上找的一个比较齐全的解释案例&#xff0c;拿来记录一下 ① : 与 的区别 : 赋值的意思。在set update select 中表示赋值的意思&#xff0c;用的比较少一般都用&#xff0c;但是在用变量实现行号时&#xff08;比如本文标题获取排列序号&#xff09;&#xff0c;一定要用:…

解决Visual Studio For Mac Restore失败的问题

之前就了解到微软出了mac版的VS&#xff0c;没太多的关注&#xff0c;自己也就是使用 DotNet Core SDK VS Code 做一些小demo。 前两天发布了DotNet Core 2.0 &#xff0c;Visual Studio For Mac 7.1 之后&#xff0c;感觉可以装起来用用&#xff0c;把win下面的项目转到Core上…

应用Etherchannel扩展企业服务的高可用性

什么是Etherchannel&#xff1f;Etherchannel可以说是Cisco特有的技术&#xff0c;也就是我们在交换机以及路由器上所要配置Etherchannel就不得不使用CISCO设备。在实际工程中一般用于出口与上层设备的连接。实际上通过Etherchannel的中文名-端口绑定就很容易理解&#xff0c;它…

Leetcode 391.完美矩形

完美矩形 我们有 N 个与坐标轴对齐的矩形, 其中 N > 0, 判断它们是否能精确地覆盖一个矩形区域。 每个矩形用左下角的点和右上角的点的坐标来表示。例如&#xff0c; 一个单位正方形可以表示为 [1,1,2,2]。 ( 左下角的点的坐标为 (1, 1) 以及右上角的点的坐标为 (2, 2) )。…

Meteor计时器

Meteor有提供它自己的setTimeout和setInterval方法。这些方法被用于确保所有全局变量都具有正确的值。它们就像普通 JavaScript 中的setTimeout 和 setInterval 一样工作。Timeout - 超时 Meteor.setTimeout 的例子。Meteor.setTimeout(function(){console.log("Timeout c…

WEB程序代码优化入手的几方面

这里对web程序方面的优化作一个总结.1.编码规范化可读性优化编码规范我想一般程序员不会不了解&#xff0c;如果你这方面是空白你应该好好补补基础了&#xff0c;做到编码规范是一个好的程序员的最基础要求&#xff0c;一个团队也应该有自己的编码规范。所以程序的优化也应该包…

【Elastic Stack(一)】Elastic Stack简介

如果你没有听说过Elastic Stack&#xff0c;那你一定听说过ELK。实际上ELK是三款软件的简称&#xff0c;分别是Elasticsearch、Logstash、Kibana组成&#xff0c;在发展的过程中&#xff0c;又有新成员Beats的加入&#xff0c;所以就形成了Elastic Stack。 所以说&#xff0c;…

c#创建、保存excel正常执行要点补疑

网上搜索C#实现excel操作的示例太多了&#xff0c;但不知道有多少是经过验证确实可行才发布出来的&#xff0c;也是因为开发需要&#xff0c;我找了一些代码却发现大多都不能正确执行完毕&#xff0c;于是决定补充自己在实践中遇到的要点以供参考。如下示例&#xff1a;usingMi…

动态更新 AGS Cache

作者&#xff1a;Flyingis 提升ArcGIS Server访问速度最佳的方式是Cache&#xff0c;将所有图层切片保存在服务器&#xff0c;客户端请求时直接访问cache好的图片&#xff0c;这里分为两种情况&#xff0c;一是所有图层都做cache&#xff0c;二是部分图层做cache&#xff0…

SVN状态图标不显示的两种解决办法

文章目录第一种方法第二种方法首先情况如下&#xff1a;这样看不到状态是不是就很难受 本博主最近也是第一次使用SVN做版本控制 然后就出现了这样的情况后来经过查询才知道SVN刚下载安装后 设置什么的都是默认的 需要手动设置一下就OK啦 第一种方法 我们先在桌面或者资源管理…

SPOJ ATOMS - Atoms in the Lab

题目链接&#xff1a;http://www.spoj.com/problems/ATOMS/ 题目大意&#xff1a;有N个原子&#xff0c;他们每秒分裂成K个新原子&#xff0c;新原子也能继续分裂。问如果要控制他的数量为M以内&#xff0c;应在什么时候使其停止分裂。其实时间为0. 解题思路&#xff1a;可以发…

hive lock命令的使用

1.hive锁表命令 hive> lock table t1 exclusive;锁表后不能对表进行操作2.hive表解锁&#xff1a; hive> unlock table t1;3.查看被锁的表 1.hive> show locks; 转载于:https://www.cnblogs.com/liyanbin/p/10237482.html

技术类人员的职业发展的4大方向

几乎每个企业都需要技术员的支持&#xff0c;生产制造型企业需要现场生产控制和工艺流程方面的技术人才&#xff1b;it等高科技行业需要大量软件研发和设备维护的硬件工程师&#xff1b;房地产、建筑工程领域需要建筑设计师、土木工程师和施工技术人员。此外&#xff0c;不论是…

Injection of @Reference dependencies failed;

配置、注解、xml什么的所有东西都没有问题 可能是接口这边所应用的jar包版本太高了 尝试将对应的版本降低试一下就好了 我这边是dubbo的版本太高导致一直出现这种问题

机器学习与数据科学 基于R的统计学习方法(基础部分)

1.1 机器学习的分类 监督学习&#xff1a;线性回归或逻辑回归&#xff0c; 非监督学习&#xff1a;是K-均值聚类&#xff0c; 即在数据点集中找出“聚类”。 另一种常用技术叫做主成分分析&#xff08;PCA&#xff09; &#xff0c; 用于降维&#xff0c; 算法的评估方法也不尽…

sql语句收集

1:随机抽取前30条select top 30 * from test order by newid()order by newid()&#xff1a;随机产生id号&#xff0c;然后根据id号排序&#xff1b;top 30&#xff1a;前30道题目。2:在排名次时&#xff0c;经常遇到取前10名&#xff0c;但刚好第11名&#xff08;12、13...&am…

atitit.php中的dwr 设计模式

atitit.php中的dwr 设计模式 1. dwr的长处相对于ajax来说。。1 2. DWR工作原理 1 3. php的dwr实现 1 4. 參考 3 1. dwr的长处相对于ajax来说。。 dwr是构建在ajax上的。。更加的dsl化。。大大简化了编写ajax的工作量。 2. DWR工作原理 是通过动态把Java类生成为Javascript。…

UML2.0工具比較

來源 前言 「工欲善其事&#xff0c;必先利其器」&#xff0c;學習UML沒有好的工具幫忙&#xff0c;往往會讓開發人員半途而廢&#xff0c;尤有甚者&#xff0c;開發人員有時會因為使用了不容易使用的開發工具而 誤認為UML是一個非常困難學習的「技術」。殊不知UML只是一種「語…

Spark快速入门

文章目录1、Spark概述1.1、什么是Spark&#xff1f;1.2、为什么要学Spark&#xff1f;1.3、Spark的特点1.3.1、运行速度快1.3.2、易用性好1.3.3、通用性强1.3.4、兼容性强2、搭建Spark集群2.1、下载2.2、环境准备2.3、配置免密登录2.4、开始安装2.5、Spark HA 高可用部署2.5.1、…