指令碼|驗證碼 ADODE.Stream完成!49行代碼,三個檔案 ,有點象本站的CGI img.exe的效果
Asp檔案:Code.Asp
資料檔案:body.Fix , Head.Fix
示範:
http://www.lfgbox.com/paintblue/code/code.asp
:D 我已經放我論壇去啦~~
下載:
http://www.lfgbox.com/download/code.rar
用法:<img src="code.asp">
在檢驗頁:判斷 Cint(request("GetCode"))=Session("GetCode")
:rolleyes: :rolleyes: :rolleyes:
別怪我做多餘勞動~~折騰代碼!寫個全新的的東東是愜意的~~
請注意下載完整的數字資料檔案~~
代碼思路就是利用 ADODB.Stream二進位對象進行二進位流的處理!
將隨機產生的數字轉換為調用映像資料中相應的資料區塊,映像資料是GBR GBR ..排部的 資料,頭是BMP的頭~~然後用ADODB.Stream 將產生的隨機數位影像資料再組合為新的一個bmp映像塊~~用Response.BinaryWrite 將其直接發送瀏覽器
Body.Fix 數字0~9 10X100豎排的RGB陣列資料3200 byte
Head.Fix 是54byte的BMP頭
如果要改變字型和顏色~~可以將bmp 10x100 映像的前54位元組去掉!
替換body.Fix檔案
以下內容為程式碼
<%
Option explicit
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
zNum = cint(8999*Rnd+1000)
Session("GetCode") = zNum
dim zimg(4),NStr
NStr=cstr(zNum)
For i=0 to 3
zimg(i)=cint(mid(NStr,i+1,1))
Next
dim Pos
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
Ados.LoadFromFile(Server.mappath("body.Fix"))
Ados1.write Ados.read(1280)
for i=0 to 3
Ados.Position=(9-zimg(i))*320
Ados1.Position=i*320
Ados1.write ados.read(320)
next
Ados.LoadFromFile(Server.mappath("head.fix"))
Pos=lenb(Ados.read())
Ados.Position=Pos
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
Response.ContentType = "image/BMP"
Ados.Position=0
Response.BinaryWrite Ados.read()
Ados.Close:set Ados=nothing
Ados1.Close:set Ados1=nothing
End Function
'Asp code Created by BlueIdea.COM Web Team V37 2003-7-25
%>