ndfweb.cn

用ASP生成BMP圖片


2009-08-09 09:27:33 (6623)



BMP圖片規則:BMP文件有54個字節的文件頭,其中包括了BMP文件標誌“BM”,文件大小,位圖文件起始位置,長,寬,位圖位數1/4/8/24(1,8個像素占1個字節;4,2個像素占1個字節;8,1個像素占1個字節;24,1個像素占3個字節;)等信息。不過最簡單的方法是先用畫圖板做一個相同大小的空圖片,把頭信息記錄下來。
BMP文件實際顯示部分,是從左下角開始,到右上角結束,詳細記錄了文件的每個像素,如果用24位位圖表示的話,用3個字節表示RGB。紅色表示就是 ff 00 ff,黑色就是00 00 00,白色是ff ff ff...
如果我們要表示一個數字或字母,我們可以用一個10X10的距陣來表示,比如1用下麵的距陣表示:
1111011111
1100011111
1111011111
1111011111
1111011111
1111011111
1111011111
1111011111
1111011111
1100000111
當然也可以用一個更大的距陣來表示一個更豐富的樣式。
明白了原理,接下來就好用程序實現了,我們用Response.BinaryWrite方法寫入文件頭,再用程序寫入文件體。
下麵是一個用程序生成瀏覽者IP地址的程序:
<%
Response.Expires = -9999
Response.AddHeader "cache-control","no-cache"
Response.ContentType = "Image/BMP"
Const cCode = "0123456789. " '數據值

Dim vColor(2)
vColor(0) = ChrB(0) & ChrB(0) & ChrB(0) '黑
vColor(1) = ChrB(255) & ChrB(255) & ChrB(255) '白

ip=request.ServerVariables("http_x_forwarded_for") '得到IP值
if ip="" then
ip=request.ServerVariables("remote_addr")
end if

ls=split(ip,".",-1,1) '劈開IP
for j=0 to 3 '處理分組
if len(ls(j))<3 then '如果長度少於3
spac=""
for k=1 to 3-len(ls(j)) '加3-len個空格
spac=spac+" "
next
ls(j)=spac+ls(j) '轉換長度足夠的ls(j)
end if
next

str="" '二次處理IP串,over
for k=0 to 3
str=str+ls(k)+"."
next
str=left(str,15)

dim vCode(15) '三次處理成數組
For x = 0 To 14
vCode(x) = mid(str,x+1,1) '等於什麼值?
vCode(x)=instr(1,cCode,vCode(x),1)-1 '值在串中是第幾?
'response.write vCode(x)&"<br>"
Next

Dim vNumber(12)
vNumber(0) = "1110000111110111101111011110111101001011110100101111010010111101001011110111101111011110111110000111"
vNumber(1) = "1111011111110001111111110111111111011111111101111111110111111111011111111101111111110111111100000111"
vNumber(2) = "1110000111110111101111011110111111111011111111011111111011111111011111111011111111011110111100000011"
vNumber(3) = "1110000111110111101111011110111111110111111100111111111101111111111011110111101111011110111110000111"
vNumber(4) = "1111101111111110111111110011111110101111110110111111011011111100000011111110111111111011111111000011"
vNumber(5) = "1100000011110111111111011111111101000111110011101111111110111111111011110111101111011110111110000111"
vNumber(6) = "1111000111111011101111011111111101111111110100011111001110111101111011110111101111011110111110000111"
vNumber(7) = "1100000011110111011111011101111111101111111110111111110111111111011111111101111111110111111111011111"
vNumber(8) = "1110000111110111101111011110111101111011111000011111101101111101111011110111101111011110111110000111"
vNumber(9) = "1110001111110111011111011110111101111011110111001111100010111111111011111111101111011101111110001111"
vNumber(10) ="1111111111111111111111111111111111111111111111111111111111111111111111111111111111110011111111001111"
vNumber(11) ="1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"

Response.BinaryWrite chrB(66)&chrB(77)&chrB(222)&chrB(17)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(54)&_
chrB(0)&chrB(0)&chrB(0)&chrB(40)&chrB(0)&chrB(0)&chrB(0)&chrB(150)&chrB(0)&chrB(0)&chrB(0)&chrB(10)&chrB(0)&chrB(0)&_
chrB(0)&chrB(1)&chrB(0)&chrB(24)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(168)&chrB(17)

Response.BinaryWrite chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&_
chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)
dim x,y,z
For x = 9 To 0 step -1 '逐行
For y = 0 To 14 '逐字
For z = 1 To 10 '逐像素的R/G/B,因為vColor()已經定義每個RGB值了,如果是8位位圖,使用一個字節即可
Response.BinaryWrite vColor(Mid(vNumber(vCode(y)), x * 10 + z , 1)) '寫入流
Next
Next
Response.BinaryWrite vColor(1) '為每一行的增加一個行尾標誌
Next
%>

當然,這個程序生成的流和位圖定義有點不太符合,圖片有點斜,大家慢慢研究吧...
下麵是我修改的網上的生成彩色隨機驗證碼的程序, 附件一直提示file1格式不對, 隻好粘在下麵
<%
Response.ContentType = "Image/BMP"
Call Com_CreatValidCode()
Sub Com_CreatValidCode()
Randomize
Dim i, ii, iii
Const cAmount = 36 '數值個數
Const cCode = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ" '數值範圍

Dim vColorData(2)
vColorData(0) = "" '黑色點要轉為彩色點,暫時不定義
vColorData(1) = ChrB(255) & ChrB(255) & ChrB(255) '白點

Dim vCode(4), vCodes '產生一組任意數
For i = 0 To 3
vCode(i) = Int(Rnd * cAmount) '數組等於總數*隨機數
vCodes=vCodes&Mid(cCode,vCode(i)+1,1) '串等於串加上後續值
Next
session("checkcode")=vCodes '記錄產生的串值

Dim vNumberData(36)
vNumberData(0) = "1110000111110111101111011110111101001011110100101111010010111101001011110111101111011110111110000111"
vNumberData(1) = "1111011111110001111111110111111111011111111101111111110111111111011111111101111111110111111100000111"
vNumberData(2) = "1110000111110111101111011110111111111011111111011111111011111111011111111011111111011110111100000011"
vNumberData(3) = "1110000111110111101111011110111111110111111100111111111101111111111011110111101111011110111110000111"
vNumberData(4) = "1111101111111110111111110011111110101111110110111111011011111100000011111110111111111011111111000011"
vNumberData(5) = "1100000011110111111111011111111101000111110011101111111110111111111011110111101111011110111110000111"
vNumberData(6) = "1111000111111011101111011111111101111111110100011111001110111101111011110111101111011110111110000111"
vNumberData(7) = "1100000011110111011111011101111111101111111110111111110111111111011111111101111111110111111111011111"
vNumberData(8) = "1110000111110111101111011110111101111011111000011111101101111101111011110111101111011110111110000111"
vNumberData(9) = "1110001111110111011111011110111101111011110111001111100010111111111011111111101111011101111110001111"
vNumberData(10) = "1111011111111101111111101011111110101111111010111111101011111100000111110111011111011101111000100011"
vNumberData(11) = "1000000111110111101111011110111101110111110000111111011101111101111011110111101111011110111000000111"
vNumberData(12) = "1110000011110111101110111110111011111111101111111110111111111011111111101111101111011101111110001111"
vNumberData(13) = "1000001111110111011111011110111101111011110111101111011110111101111011110111101111011101111000001111"
vNumberData(14) = "1000000111110111101111011011111101101111110000111111011011111101101111110111111111011110111000000111"
vNumberData(15) = "1000000111110111101111011011111101101111110000111111011011111101101111110111111111011111111000111111"
vNumberData(16) = "1110000111110111011110111101111011111111101111111110111111111011100011101111011111011101111110001111"
vNumberData(17) = "1000100011110111011111011101111101110111110000011111011101111101110111110111011111011101111000100011"
vNumberData(18) = "1100000111111101111111110111111111011111111101111111110111111111011111111101111111110111111100000111"
vNumberData(19) = "1110000011111110111111111011111111101111111110111111111011111111101111111110111110111011111000011111"
vNumberData(20) = "1000100011110111011111011011111101011111110001111111010111111101101111110110111111011101111000100011"
vNumberData(21) = "1000111111110111111111011111111101111111110111111111011111111101111111110111111111011110111000000011"
vNumberData(22) = "1000100011110010011111001001111100100111110101011111010101111101010111110101011111010101111001010011"
vNumberData(23) = "1000100011110011011111001101111101010111110101011111010101111101100111110110011111011001111000110111"
vNumberData(24) = "1110001111110111011110111110111011111011101111101110111110111011111011101111101111011101111110001111"
vNumberData(25) = "1000000111110111101111011110111101111011110000011111011111111101111111110111111111011111111000111111"
vNumberData(26) = "1110001111110111011110111110111011111011101111101110111110111011111011101001101111011001111110001011"
vNumberData(27) = "1000001111110111011111011101111101110111110000111111010111111101101111110110111111011101111000110011"
vNumberData(28) = "1110000011110111101111011110111101111111111001111111111001111111111011110111101111011110111100000111"
vNumberData(29) = "1000000011101101101111110111111111011111111101111111110111111111011111111101111111110111111110001111"
vNumberData(30) = "1000100011110111011111011101111101110111110111011111011101111101110111110111011111011101111110001111"
vNumberData(31) = "1000100011110111011111011101111101110111111010111111101011111110101111111010111111110111111111011111"
vNumberData(32) = "1001010011110101011111010101111101010111110101011111001001111110101111111010111111101011111110101111"
vNumberData(33) = "1000100011110111011111101011111110101111111101111111110111111110101111111010111111011101111000100011"
vNumberData(34) = "1000100011110111011111011101111110101111111010111111110111111111011111111101111111110111111110001111"
vNumberData(35) = "1100000011110111011111111101111111101111111110111111110111111111011111111011111111101110111100000011"

Response.BinaryWrite ChrB(66) & ChrB(77) & ChrB(230) & ChrB(4) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) &_
ChrB(0) & ChrB(0) & ChrB(54) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(40) & ChrB(0) &_
ChrB(0) & ChrB(0) & ChrB(40) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(10) & ChrB(0) &_
ChrB(0) & ChrB(0) & ChrB(1) & ChrB(0)

Response.BinaryWrite ChrB(24) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(176) & ChrB(4) &_
ChrB(0) & ChrB(0) & ChrB(18) & ChrB(11) & ChrB(0) & ChrB(0) & ChrB(18) & ChrB(11) &_
ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) & ChrB(0) &_
ChrB(0) & ChrB(0)
For i = 9 To 0 Step -1 '行
For ii = 0 To 3 '字數
For iii = 1 To 10 '像素點
if Mid(vNumberData(vCode(ii)), i * 10 + iii , 1) ="0" then '產生彩色點,減去一個固定值,可使顏色偏深
dim a,b,c
a=abs(Rnd * 256-60)
b=abs(Rnd * 256-128)
c=abs(Rnd * 256-60)
vColorData(0) = ChrB(a) & ChrB(b) & ChrB(c)
Response.BinaryWrite vColorData(Mid(vNumberData(vCode(ii)), i * 10 + iii , 1))
else
dim d,e,f '產生彩色背景,顏色偏淺,也可以隨機生成噪點做背景
d=abs(Rnd * 255)
e=abs(Rnd * 255)
f=abs(Rnd * 255)
if d+e+f>580 then
vColorData(1) = ChrB(d) & ChrB(e) & ChrB(f)
Response.BinaryWrite vColorData(Mid(vNumberData(vCode(ii)), i * 10 + iii , 1))
else
Response.BinaryWrite vColorData(Mid(vNumberData(vCode(ii)), i * 10 + iii , 1))
end if
end if
Next
Next
Next
End Sub
%>


------------------------------------------------------------------------------

另做的一個小IP圖片
--------------------------------------------------------------------------------
黑白8位位圖圖片,非常正規,圖片非常小:262個字節
注:8位黑白位圖,指8個像素占一個字節,第一個點是黑色,另七個點是白色的話,字節值是80;第二點是黑色,其它點是白色,字節值是40,以此類推...多個點是黑色加在一起,8個像素全是黑色,字節值是FF...
<%
Response.Expires = -9999
Response.AddHeader "cache-control","no-cache"
Response.ContentType = "Image/BMP"
Const cCode = "0123456789. " '數據值

Dim vColor(2)
vColor(0) = ChrB(0) '黑
vColor(1) = ChrB(80) '白

ip=request.ServerVariables("http_x_forwarded_for") '得到IP值
if ip="" then
ip=request.ServerVariables("remote_addr")
end if

ls=split(ip,".",-1,1) '劈開IP
for j=0 to 3 '處理分組
if len(ls(j))<3 then '如果長度少於3
spac=""
for k=1 to 3-len(ls(j)) '加3-len個空格
spac=spac+" "
next
ls(j)=spac+ls(j) '轉換長度足夠的ls(j)
end if
next

str="" '二次處理IP串
for k=0 to 3
str=str+ls(k)+"."
next
str=left(str,15)

Dim vNumber(12)
vNumber(0) = "1110000111110111101111011110111101001011110100101111010010111101001011110111101111011110111110000111"
vNumber(1) = "1111011111110001111111110111111111011111111101111111110111111111011111111101111111110111111100000111"
vNumber(2) = "1110000111110111101111011110111111111011111111011111111011111111011111111011111111011110111100000011"
vNumber(3) = "1110000111110111101111011110111111110111111100111111111101111111111011110111101111011110111110000111"
vNumber(4) = "1111101111111110111111110011111110101111110110111111011011111100000011111110111111111011111111000011"
vNumber(5) = "1100000011110111111111011111111101000111110011101111111110111111111011110111101111011110111110000111"
vNumber(6) = "1111000111111011101111011111111101111111110100011111001110111101111011110111101111011110111110000111"
vNumber(7) = "1100000011110111011111011101111111101111111110111111110111111111011111111101111111110111111111011111"
vNumber(8) = "1110000111110111101111011110111101111011111000011111101101111101111011110111101111011110111110000111"
vNumber(9) = "1110001111110111011111011110111101111011110111001111100010111111111011111111101111011101111110001111"
vNumber(10) ="1111111111111111111111111111111111111111111111111111111111111111111111111111111111110011111111001111"
vNumber(11) ="1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"

dim x,y,vCode(15) '三次處理成數組
For x = 0 To 14
vCode(x) = mid(str,x+1,1) '等於什麼值?
vCode(x)=instr(1,cCode,vCode(x),1)-1 '值在串中是第幾?
Next

Response.BinaryWrite chrB(66)&chrB(77)&chrB(8)&chrB(1)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(62)&_
chrB(0)&chrB(0)&chrB(0)&chrB(40)&chrB(0)&chrB(0)&chrB(0)&chrB(150)&chrB(0)&chrB(0)&chrB(0)&chrB(10)&chrB(0)&chrB(0)&_
chrB(0)&chrB(1)&chrB(0)&chrB(1)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(202)
Response.BinaryWrite chrB(0)&chrB(0)&chrB(0)&chrB(18)&chrB(11)&chrB(0)&chrB(0)&chrB(18)&chrB(11)&chrB(0)&chrB(0)&_
chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(0)&chrB(255)&chrB(255)&chrB(255)&chrB(0)&chrB(0)&_
chrB(0)&chrB(0)&chrB(0)

dim points(10)
for x=9 to 0 step -1 '處理成10行150列的像素串
points(x)=""
for y=0 to 14
points(x)=points(x)&mid(vNumber(vCode(y)),x*10+1,10)
next
for z=0 to 18 '劈開像素串,分別處理
lsstr=mid(points(x),z*8+1,8)
byteval=0
if mid(lsstr,1,1)="0" then byteval=byteval+128
if mid(lsstr,2,1)="0" then byteval=byteval+64
if mid(lsstr,3,1)="0" then byteval=byteval+32
if mid(lsstr,4,1)="0" then byteval=byteval+16
if mid(lsstr,5,1)="0" then byteval=byteval+8
if mid(lsstr,6,1)="0" then byteval=byteval+4
if mid(lsstr,7,1)="0" then byteval=byteval+2
if mid(lsstr,8,1)="0" then byteval=byteval+1
response.binarywrite chrb(byteval)
next
Response.BinaryWrite vColor(0) '寫行尾標誌
next
Response.BinaryWrite vColor(0) '寫圖尾標誌
%>
本文版权:http://www.ndfweb.cn/news-408.html
  NDF俱乐部
  国际域名注册
  建站咨询
简体中文 NDF网站建设淘宝店 | ICO图标在线生成 | 外贸网站建设 | 联系我们
©2007-2025 NDF Corporation 鲁ICP备08005967号 Sitemap - RSSRSS订阅