機能: ASP プログラムを使用して、ページ内の電話番号を画像形式で生成します。
ここに引用があります:
<%
Com_CreatValidCode(Request.QueryString("tel")) を呼び出す
パブリック サブ Com_CreatValidCode(pTel)
'----------キャッシュを無効にする
応答.期限切れ = 0
Response.AddHeader "プラグマ"、"キャッシュなし"
Response.AddHeader "キャッシュ制御"、"キャッシュなし"
Response.ContentType = "画像/BMP"
ランダム化
Dim i、ii、iii 、rndColor、strLen、sql、rs
Const cOdds = 5 '--------ノイズが現れる確率
Const str="0123456789-"
strLen = len(pTel)
rndColor = ChrB(cint(rnd*255)) & ChrB(cint(rnd*255)) & ChrB(cint(rnd*255))
'----------カラーデータ(文字、背景)
ディム vColorData(1)
'vColorData(0) = ChrB(0) & ChrB(0) & ChrB(0) '----青 0、緑 0、赤 0 (黒)
'vColorData(1) = ChrB(255) & ChrB(255) & ChrB(255) '----青 250、緑 236、赤 211 (水色)
'vColorData(0) = ChrB(197) & ChrB(106) & ChrB(49) '---- 青 0、緑 0、赤 0 (黒)
'vColorData(1) = ChrB(238) & ChrB(210) & ChrB(193) '-----青 250、緑 236、赤 211 (水色)
vColorData(0) = ChrB(0) & ChrB(0) & ChrB(0) '--------青 0、緑 0、赤 0 (黒)
vColorData(1) = ChrB(205) & ChrB(237) & ChrB(245) '-----------青 250、緑 236、赤 211 (水色)
'---- - --------------- ランダムにキャラクターを生成する
ランダム化
Dim vCode()
redim vCode(strLen-1)
i = 0 から strLen-1 まで
vCode(i) =instr(1,str,mid(pTel,i+1,1),1)-1
次へ
'----------キャラクターデータ
Dim vNumberData(11)
'Verdana フォント
vNumberData(0) = "11111111111000111101110111011101110111011101110111011101110111011110001111111111"
vNumberData(1) = "11111111111101111110011111110111111101111111011111110111111101111110001111111111"
vNumberData(2) = "11111111111000111101110111011101111110111111011111101111110111111100000111111111"
vNumberData(3) = "11111111111000111101110111111101111100111111110111111101110111011110001111111111"
vNumberData(4) = "111111111111101111110011111010111110101111011011111000011111101111111001111111111"
vNumberData(5) = "11111111110000011101111111011111110000111111110111111101110111011110001111111111"
vNumberData(6) = "11111111111000111101101111011111110000111101110111011101110111011110001111111111"
vNumberData(7) = "111111111100000111011011111110111111011111110111111101111111011111110111111111111"
vNumberData(8) = "11111111111000111101110111011101111000111101110111011101110111011110001111111111"
vNumberData(9) = "11111111111000111101110111011101110111011110000111111101111011011110000111111111"
vNumberData(10) = "11111111111111111111111111111111111111111000001111111111111111111111111111111"
vNumberData(11) = "1111111111111111111111111111111111111111111111111111111111111111111111111111"
'-----------------出力画像ファイルのヘッダー<br>
Response.BinaryWrite ChrB(66) & ChrB(77) &chrb(((strLen*8*10*3+54) mod 256)) & chrb(((strLen*8*10*3+54) 256)mod 256 ) & ChrB((((strLen*8*10*3+54) 256)256)mod 256) & ChrB((((strLen*8*10*3+54) 256)256) 256)mod 256) & 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(strLen*8) & 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((strLen*8*10*3)mod 256)&ChrB(((strLen*8*10*3)256)mod 256)&ChrB((((strLen*8*10*3)256)256 )mod 256)&ChrB(((((strLen*8*10*3)256)256)256)mod 256)&_
ChrB(196) & ChrB(14) & ChrB(0) & ChrB(0) & ChrB(196) & ChrB(14)&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 strLen-1 '-----すべての単語を調べます
For iii = 1 To 8 '--------すべてのピクセルを通過します
'--------画像データを行ごと、ワードごと、ピクセルごとに出力します
If Rnd * 99 + 1 < cOdds then '-------- ランダムにノイズを生成
Response.BinaryWrite rndColor
それ以外
Response.BinaryWrite vColorData(Mid(vNumberData(vCode(ii)), i * 8 + iii, 1))
終了の場合
次
次
次
エンドサブ
%>
上記のコードを img.asp として保存し、電話番号を表示する場所に <img src="img.asp?tel=010-0000000"> を挿入します。