ASP制作彩色效驗(yàn)碼的實(shí)例分享
本文將給大家分享到的是ASP彩色效驗(yàn)碼的制作方法,對(duì)ASP有很大興趣的朋友可以根據(jù)下面的步驟試一試。
要讀懂這些代碼主要是要了解ASP中操作二進(jìn)制數(shù)據(jù)的對(duì)象ADODB.Stream!本程序主要用的就是Adodb.Stream,如果你有這個(gè)基礎(chǔ),就可以進(jìn)一步添加更多的功能如加入雜點(diǎn),漸變底色,數(shù)字行列錯(cuò)位,筆畫(huà)短點(diǎn),提高被ocr識(shí)別的不可能。目前還沒(méi)有好的識(shí)別引擎,昨天下載了個(gè)號(hào)稱能識(shí)別圖像驗(yàn)證碼90%的,把4321識(shí)別成 89910,所以圖像碼還是比較安全的。
在網(wǎng)上看到有暴力破解的方法,如果我用圖像附加碼+禁止外部提交+10次密碼錯(cuò)誤封帳號(hào) +50次密碼錯(cuò)誤瑣死IP+10秒的防刷新間隔注冊(cè)頁(yè),登陸頁(yè)均要加上+禁止外部提交,這樣,暴力破解應(yīng)該就沒(méi)戲了。
Asp文件:Code.Asp
數(shù)據(jù)文件:body.Fix , Head.Fix
演示:本站PHP故無(wú)演示
用法:<img src="code.asp">
稍微修改一下代碼,給一個(gè)可以自己修改數(shù)字的版本:點(diǎn)擊下載,用圖像軟件打開(kāi) body.bmp 直接編輯自己需要的字體和顏色!
code.asp文件:
Response.buffer = true
NumCode
Function NumCode()
Response.Expires = -1
Response.AddHeader "Pragma","no-cache"
Response.AddHeader "cache-ctrol","no-cache"
dim zNum,i,j
dim Ados,Ados1
Randomize timer
生成隨機(jī)四位數(shù)字:
zNum = cint(8999*Rnd+1000)
傳遞給session
Session("GetCode") = zNum
該for循環(huán)是將隨機(jī)數(shù)字放入一個(gè)下標(biāo)3的數(shù)組,便于提供給后面的陣列變換
dim zimg(3),NStr
NStr=cstr(zNum)
For i=0 to 3
zimg(i)=cint(mid(NStr,i+1,1))
Next
dim Pos
'定義二個(gè) ADODB.Stream binary對(duì)象,作圖像數(shù)據(jù)操作之用:
set Ados=Server.CreateObject("Adodb.Stream")
Ados.Mode=3
Ados.Type=1
Ados.Open
set Ados1=Server.CreateObject("Adodb.Stream")
Ados1.Mode=3
Ados1.Type=1
Ados1.Open
'載入0~9的數(shù)字?jǐn)?shù)據(jù)10x100的,Gbr的陣列數(shù)據(jù),每個(gè)320字節(jié),10個(gè)數(shù)字3200byte
'BGR一個(gè)點(diǎn),10x10個(gè)點(diǎn)一個(gè)數(shù)字,一個(gè)點(diǎn)三個(gè)字節(jié)(二進(jìn)制8位,16進(jìn)制 00~FF)
'一行10個(gè)點(diǎn) 30字節(jié) + 行結(jié)束標(biāo)記 00 00 二字節(jié) 32字節(jié),所以一個(gè)10x100寬小于長(zhǎng)的圖像每個(gè)數(shù)字10x10是320字節(jié)
'長(zhǎng)大于寬的則無(wú)行結(jié)束標(biāo)記 0000,直接是300字節(jié)
這些就是BMP 24bit的數(shù)據(jù)詳細(xì)信息了
'至于頭部,也很簡(jiǎn)單,包含長(zhǎng)寬,圖像開(kāi)始標(biāo)記等等~~才54字節(jié),遠(yuǎn)沒(méi)jpg什么的復(fù)雜
Ados.LoadFromFile(Server.mappath("body.Fix"))
Ados1.write Ados.read(1280)
'第一個(gè)for循環(huán),按生成的隨機(jī)數(shù)字順序從 10X100的數(shù)字陣列中提取出相應(yīng)的四個(gè)數(shù)字,但是豎排的數(shù)字陣列
for i=0 to 3
Ados.Position=(9-zimg(i))*320
Ados1.Position=i*320
Ados1.write ados.read(320)
next
'清空已經(jīng)用完的ADOS的數(shù)據(jù),調(diào)入替換新的圖像頭54字節(jié)的頭文件
Ados.LoadFromFile(Server.mappath("head.fix"))
Pos=lenb(Ados.read())
Ados.Position=Pos ' 指定Pos位置,即可再偏移54字節(jié)的位置添加圖形數(shù)據(jù),第二個(gè)for循環(huán),進(jìn)行數(shù)字的陣列變換,由豎排的塊轉(zhuǎn)換為橫排的數(shù)字塊,方法是隔320字節(jié)抽取4次30字節(jié)寫(xiě)入ados對(duì)象,再抽取偏移第二行的圖像數(shù)據(jù),30字節(jié)是因?yàn)閎mp 寬大于長(zhǎng)時(shí)無(wú)00 00的行結(jié)束標(biāo)記
for i=0 to 9 step 1
for j=0 to 3
Ados1.Position=i*32+j*320
Ados.Position=Pos+30*j+i*120
Ados.write ados1.read(30)
next
next
Ados.Position=0
response.BinaryWrite '直接向客戶端發(fā)送圖像數(shù)據(jù)
Response.ContentType = "image/BMP"
Response.BinaryWrite Ados.read()
Ados.Close:set Ados=nothing
Ados1.Close:set Ados1=nothing
End Function
運(yùn)用在頁(yè)面中:
提交頁(yè):
------login.asp-----
<form action="chklogin.asp" method="post">
帳號(hào):<input name="acco" type="text"><br>
密碼:<input name="pass" type="text"><br>
校驗(yàn)碼:<input name="GetCode" type="text"><img src="code.asp">
</form>
處理頁(yè):
--------chklogin.asp--------
<%
dim GetCode,valicode
GetCode=int(request("GetCode")
valicode=int(Session("GetCode")
if GetCode<>valicode then
response.write ("驗(yàn)證碼輸入錯(cuò)誤,請(qǐng)重輸入")
response.end
end if
%>