ASP 验证码(支持 SP2,防破解)

验证码示例:

<%
if isempty(session("getcode")) or session("getcode") <> ucase(request.form("form_code")) then
response.write "验证码输入错误"
response.end
else
session("getcode") = empty " 清空session
response.write "验证码输入正确"
response.end
end if
%>
验证码代码:

<%
option explicit " 显示声明
class com_gifcode_class
"""""""""""""""""""""""""""""""""""""""""""""
" author: layen support@ssaw.net 84815733(qq)
" thanks: laomi, laomiao, netrube
" 2006-01-02
"""""""""""""""""""""""""""""""""""""""""""""
public noisy, count, width, height, angle, offset, border
private graph(), margin(3)
private sub class_initialize()
randomize
noisy = 16 " 干扰点出现的概率
count = 4 " 字符数量
width = 80 " 图片宽度
height = 20 " 图片高度
angle = 2 " 角度随机变化量
offset = 20 " 偏移随机变化量
border = 1 " 边框大小
end sub
public function create()
const ccharset = "123456789"
dim i, x, y
dim vvalidcode : vvalidcode = ""
dim vindex
redim graph(width-1, height-1)
for i = 0 to count - 1
vindex = int(rnd * len(ccharset))
vvalidcode = vvalidcode + mid(ccharset, vindex+1 , 1)
setdraw vindex, i
next
create = vvalidcode
end function
sub setdot(px, py)
if px * (width-px-1) >= 0 and py * (height-py-1) >= 0 then
graph(px, py) = 1
end if
end sub
public sub setdraw(pindex, pnumber)
" 字符数据
dim dotdata(8)
dotdata(0) = array(30, 15, 50, 1, 50, 100)
dotdata(1) = array(1 ,34 ,30 ,1 ,71, 1, 100, 34, 1, 100, 93, 100, 100, 86)
dotdata(2) = array(1, 1, 100, 1, 42, 42, 100, 70, 50, 100, 1, 70)
dotdata(3) = array(100, 73, 6, 73, 75, 6, 75, 100)
dotdata(4) = array(100, 1, 1, 1, 1, 50, 50, 35, 100, 55, 100, 80, 50, 100, 1, 95)
dotdata(5) = array(100, 20, 70, 1, 20, 1, 1, 30, 1, 80, 30, 100, 70, 100, 100, 80, _ 100, 60, 70, 50, 30, 50, 1, 60)
dotdata(6) = array(6, 26, 6, 6, 100, 6, 53, 100)
dotdata(7) = array(100, 30, 100, 20, 70, 1, 30, 1, 1, 20, 1, 30, 100, 70, 100, 80, _ 70, 100, 30, 100, 1, 80, 1, 70, 100, 30)
dotdata(8) = array(1, 80, 30, 100, 80, 100, 100, 70, 100, 20, 70, 1, 30, 1, 1, 20, _ 1, 40, 30, 50, 70, 50, 100, 40)
dim vextent : vextent = width / count
margin(0) = border + vextent * (rnd * offset) / 100 + margin(1)
margin(1) = vextent * (pnumber + 1) - border - vextent * (rnd * offset) / 100
margin(2) = border + height * (rnd * offset) / 100
margin(3) = height - border - height * (rnd * offset) / 100
dim vstartx, vendx, vstarty, vendy
dim vwidth, vheight, vdx, vdy, vdeltat
dim vangle, vlength
vwidth = int(margin(1) - margin(0))
vheight = int(margin(3) - margin(2))
" 起始坐标
vstartx = int((dotdata(pindex)(0)-1) * vwidth / 100)
vstarty = int((dotdata(pindex)(1)-1) * vheight / 100)
dim i, j
for i = 1 to ubound(dotdata(pindex), 1)/2
if dotdata(pindex)(2*i-2) <> 0 and dotdata(pindex)(2*i) <> 0 then
" 终点坐标
vendx = (dotdata(pindex)(2*i)-1) * vwidth / 100
vendy = (dotdata(pindex)(2*i+1)-1) * vheight / 100
" 横向差距
vdx = vendx - vstartx
" 纵向差距
vdy = vendy - vstarty
" 倾斜角度
if vdx = 0 then
vangle = sgn(vdy) * 3.14/2
else
vangle = atn(vdy / vdx)
end if
" 两坐标距离
if sin(vangle) = 0 then
vlength = vdx
else
vlength = vdy / sin(vangle)
end if
" 随机转动角度
vangle = vangle + (rnd - 0.5) * 2 * angle * 3.14 * 2 / 100
vdx = int(cos(vangle) * vlength)
vdy = int(sin(vangle) * vlength)
if abs(vdx) > abs(vdy) then vdeltat = abs(vdx) else vdeltat = abs(vdy)
for j = 1 to vdeltat

时间: 2024-10-29 02:22:34

ASP 验证码(支持 SP2,防破解)的相关文章

asp验证码源码

asp验证码源码 调用方法,是b.htm 页面  <form name="form1">   <Input type="text" name="a"><br>   <input type="text" name="b"><br><span><img id="yzm" src="yzm.asp"

asp get post sql防注入函数

asp get post sql防注入函数 '----实现get请求的注入的拦截----- dim sql_injdata,Sql_Inj,SQL_Get,Sql_Post,Sql_DATA SQL_injdata = "'|and|exec|insert|select|delete|update|count|*|%|chr|mid|master|truncate|char|declare" SQL_inj = split(SQL_Injdata,"|") If R

员工-再好的盾也有茅可以刺破,软件怎么加密才能有效防破解啊!!!!!!!

问题描述 再好的盾也有茅可以刺破,软件怎么加密才能有效防破解啊!!!!!!! 我们刚发布的软件几个月才有点收益,后面单越来越少,原来软件被破解盗版了,老板只能躲厕所里哭了,我们员工被那个K啊,有没有亡羊补牢的办法,求大神解救!! 解决方案 对,你可以做一些破解,注册机.破解补丁各种都做一些,做的和真的破解差不多,你也到处发,并且故意混淆视听,说真的破解有这个那个问题,同时你的破解也故意感觉能用,但是一到关键时刻就歇菜. 把盗版的形象搞臭,让用户觉得你的软件很难破解,破解程序都不靠谱. 解决方案二

提升网站安全性之修改服务器SSH密码防破解篇

提升网站安全性之修改服务器SSH密码防破解篇,网站服务器帐号密码被暴力破解已经不是一个新鲜的话题了,那么我们服务器遭到暴力破解怎么处理?今天小小残就教大家如何防止自己的网站服务器遭到暴力破解. 什么是暴力破解? 暴力破解或称为穷举法,是一种针对于密码的破译方法,即将密码进行逐个推算直到找出真正的密码为止.例如一个已知是四位并且全部由数字组成的密码,其可能共有10000种组合,因此最多尝试10000次就能找到正确的密码.理论上利用这种方法可以破解任何一种密码,问题只在于如何缩短试误时间.有些人运用

支持中文/英文/数字的动网ASP验证码类修改教程

完美支持中文验证码,英文及数字验证码. 设置起来相对比较简单,打开文件(Dv_GetCode.asp)进行相应参数修改: 以下是引用片段:   mCodeType     = 0        '0数字,1字母,2汉字     mCodeTotal    = 4        '生成的验证码个数     mMaxWidth    = 30        '可取的一个字符的最大宽度     mMinWidth    = 25        '可取的一个字符的最小宽度     mMaxHeight 

修改了一个很不错的php验证码(支持中文)_php技巧

php英文验证码captcha.class.php 复制代码 代码如下: <?php class Captcha { private $width; private $height; private $codeNum; private $code; private $im; function __construct($width=80, $height=20, $codeNum=4) { $this->width = $width; $this->height = $height; $t

用ASP实现支持附件的EMail系统

大家经常探讨使用asp,而不使用其他组建能否实现文件的上传,从而开发出支持邮件附件的邮件系统,答案是可以的. 以下是发送邮件的页面,邮件的帐号是员工号,假设是5位的数字,sendmail.asp当然是在合法登陆后才能够看到的 <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <link rel="st

ASP验证码的程序及原理

程序|验证码   ##### 版权所有 转载请保留 谢谢合作   ##### 部分程序取自网络   ##### 作者:扬子   ##### Email: yangzinet@hotmail.com   ##### QQ: 21112856   ##### WebSite: www.tingfo.net         一共4个页面:form.asp; chk.asp; num.asp; count.asp   得到一个随即数字.加密!   解密后成成XBM图片   利用session 判断   

ASP 验证码的程序及原理

程序|验证码 ##### 版权所有 转载请保留 谢谢合作 ##### 部分程序取自网络 ##### 作者:扬子 ##### Email: yangzinet@hotmail.com ##### QQ: 21112856##### WebSite: www.tingfo.net 一共4个页面:form.asp; chk.asp; num.asp; count.asp得到一个随即数字.加密!解密后成成XBM图片利用session 判断 form.asp<%'### To encrypt/decryp