在网页中,服务器端生成的验证码图片有什么要求,比如字体,颜色,图片大小,干扰线等等

作者&投稿:宇文儿 (若有异议请与网页底部的电邮联系)
求一些验证码图片比较简单的网站。要求:1.验证码字体只有字母或数字2.字母不扭曲3.字母与背景色差较大~

www.baidu.com

一般是因为路径错误,你用F12查一下这个图片的路径是怎么样的,有没有正确调用到你文件夹中的图片

一.常见的验证码
1,四位数字,随机的一数字字符串,最原始的验证码,验证作用几乎为零。

2,CSDN网站用户登录用的是GIF格式,目前常用的随机数字图片验证码。图片上的字符比较中规中矩,验证作用比上一个好。没有基本图形图像学知识的人,不可破!可惜读取它的程序,在CSDN使用它的第一天,好像就在论坛里发布了,真是可怜!

3,QQ网站用户登录用的是PNG格式,图片用的随机数字+随机大写英文字母,整个构图有点张扬,每刷新一次,每个字符还会变位置呢!有时候出来的图片,人眼都识别不了,厉害啊…

4,MS的hotmail申请时候的是BMP格式, 随机数字+随机大写英文字母+随机干扰像素+随机位置。

5,Google的Gmail注册时候的是JPG格式,随机英文字母+随机颜色+随机位置+随机长度。

6,其他各大论坛的是XBM格式,内容随机。

二.验证码作用分析

验证码起源:因为攻击者会使用有害程序注册大量的 Web 服务帐户(如 Passport)。攻击者可以使用这些帐户为其他的用户制造麻烦,如发送垃圾邮件或通过同时反复登录多个帐户来延缓服务的速度。在大多数情况下,自动注册程序不能识别此图片中的字符。简单的说呢,就是防止攻击者编写程序,自动注册,重复登录暴力破解密码。验证码技术应运而生。

验证码实现流程:服务器端随机生成验证码字符串,保存在内存中,并写入图片,发送给浏览器端显示,浏览器端输入验证码图片上字符,然后提交服务器端,提交的字符和服务器端保存的该字符比较是否一致。一致就继续,否则返回提示。攻击者编写的robot程序,很难识别验证码字符,顺利的完成自动注册,登录。。。。。。。。。而用户可以识别填写,所以这就实现了阻挡攻击的作用。而图片的字符识别,就是看图片上的干扰强度了。就实际的效果来说,验证码只是增加攻击者的难度,而不可能完全的防止。

1,论坛中的验证码的作用
目前,不少网站为了防止用户利用机器人自动注册、登录、灌水,都采用了验证码技术。所谓验证码,就是将一串随机产生的数字或符号,生成一幅图片,图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输入表单提交网站验证,验证成功后才能使用某项功能。
因为你的WEB站有时会碰到客户机恶意攻击,其中一种很常见的攻击手段就是身份欺骗它通过在客户端脚本写入一些代码,然后利用其客户机在网站论坛反复登陆,或者攻击者创建一个HTML窗体,其窗体如果包含了你注册窗体或发帖窗体等相同的字段,然后利用"http-post"传输数据到服务器,服务器会执行相应的创建帐户,提交垃圾数据等操作,如果服务器本身不能有效验证并拒绝此非法操作,它会很严重耗费其系统资源,降低网站性能甚至使程序崩溃.
而现在流行的判断访问WEB程序是合法用户还是恶意操作的方式,就是采用 一种叫 "字符校验"的技术.WEB网站像现在的动网论坛,他采用达到方法是为客户提供一个包含随即字符串的图片,用户必须读取这些字符串,然后随 登陆窗体或者发帖窗体等用户创建的窗体一起提交.因为人的话,可以很容易读出图片中的数字,但如果是一段客户端攻击代码,通过一般手段是很难识别验证码的.这样可以确保当前访问是来自一个人而非机器.
编程实现原理:使用某种动态编程语言,比如PHP,ASP,随即生成一个随机数,大多为4位数字和字母,或者是数字和字母的组合,生成以后,用GD库的支持生成一张根据随机数来确定的图片,把随机数写入到session中,传递到要验证的页面,生成的图片显示给登陆着,并要求登陆者输入该随机数内容,提交到验证页面,验证session的内容和提交的内容是否一致,这就是大致的思路!那么怎么编写验证码程序呢,相信Google一下,就有很多现成的代码。

2,申请QQ号时候验证码的作用

如今你要申请一个QQ号,需要输入很复杂的验证码:验证码由若干个汉字组成,还加上了花哩唬哨的背景,使得有些汉字实在难以辨认。腾讯这么做,是为了防止有人利用软件批量获取QQ号码----每次提交都要输入随机生成的验证码,这是软件难以做到的。

三.图片验证码技术之一:利用Xbm格式图片
生成验证代码的技术有很多,这里只说与我们论坛有关系的这项技术。
x-xbitmap格式的图片(以下简称为Xbm格式)特殊,就在于它并不跟gif,jpg等图片格式一样,是一个真正的纯2进制图片格式,而是ascii码文件--换句话说,它是一个纯文本文件,在Windows系统下,系统浏览器将它翻译成图片来进行显示。
下面让我们先来制作一个Xbm图形格式图片:
新建一个文本文件,将以下内容复制进去:
#define counter_width 48
#define counter_height 9
static unsigned charcounter_bits[]={ff,3c,7c,3c,70,3c,fe,7c,fe,7c,78,7c,ee,ee,ee,ee,7c,ee,e0,ee,60,ee,74,ee,70,fe,30,
fe,70,fe,38,ec,e0,ec,70,ec,1c,e0,ee,e0,70,e0,fe,7e,fe,7e,70,7e,fe,3c,7c,3c,70,3c}
然后,将此文本文件保存为名字为 test.Xbm的文件。
接下来,让我们看看如果在ie中打开它,会出现什么情形??(新开一个ie,然后将test.Xbm直接拖拽到它上面),哈,出现了如下图一样的情景,在浏览器中出来的,已经不是我们的文本,而是一个黑白的图片了!
让我们看看上面那代码中,每一行的意义:
#define counter_width 48 这里定义了图片的宽度,一般都设置为8的整数倍,因为我们想显示的是6个数字,所以就设置成了8*6=48的宽度
#define counter_height 9 这里设置了图片的高度,可以任意设置,但是注意,这里的数字直接决定了下面的数组中,是用几组数来表示一个显示出的数字
static unsigned char counter_bits[]={7c,3c,7c,3c,70,3c,fe,7c,fe,7c,78,7c,ee,ee,ee,ee,7c,ee,e0,ee,60,ee,74,ee,70,fe,30,
fe,70,fe,38,ec,e0,ec,70,ec,1c,e0,ee,e0,70,e0,fe,7e,fe,7e,70,7e,fe,3c,7c,3c,70,3c}
在这里,是图片用来显示内容的十六进制的代码,在这里,是9*6=54个数字来表示,值得一提的是,由于在图片显示中,是显示完了一行后,再显示第2行,直到最后一行,因此更为准确的描述是6*9显示,每6个数表示一行(因为我们显示了6个数字),一共9行(我们的定义中,是采用的高度为9的数组)
正如static unsigned char英文意思为静态的,无符号的,烧焦的。它只能用来显示黑白两种颜色。二进制中的1将来用显示为黑色,0为白色。
因此,上面的7c、3c这样的数字,就是一个256位的2进制,其中的1表示黑色,0表示白色,由此绘制出每个数字的图形。
由于Xbm文件的性质决定,它只能显示黑/白两种颜色,而且以数组的方式来表现每个要显示的图形,注定了不能用它生成太复杂的图案。那么,这样的图片格式到底有什么用呢??当然有的,不少asp论坛/聊天室的登陆验证码,就是用这样的方法在asp中动态生成的。

四.为什么要打补丁才能正常显示呢?
在WindowsXP SP2更改后的安全策略中,因为基于安全因素的考虑,默认去掉了对 image/x-xbitmap 图片格式的支持(该图片的后缀名为Xbm)。,为什么微软在XP的SP2升级包中又要禁止掉它呢??这是因为Xbm的漏洞。
Microsoft Internet EXPlorer和Outlook EXPress在处理WEB页,HTML邮件,EMAIL附件中畸形Xbm图象文件会导致崩溃,问题存在于对Xbm文件中的内容缺少检查,MSIE按照图象规定的长度和宽度分配内存,攻击者可以提高超大的长度和宽度数值导致系统消耗内存或者访问冲突。
换句话说,如果构造一个长宽的尺寸特别大的Xbm文件,很容易导致Windows的内存耗尽,导致程序无响应或者死机。本身来说,这不算一个特别严重的漏洞,因为根据安全公告,无法造成溢出,不会存在太大的权限漏洞。但是由于XP的SP2强调安全性,因此将Xbm功能禁用了。从这点上可以看出,SP2对于安全的确比较重视,将有漏洞的功能基本上都补上或禁用了,作为网络管理员,我对微软的做法表示支持,因为操作系统默认设置的不安全,常常是造成非专业用户被攻击的首要因素。
解禁方法:
由此看出,以后我们访问某些采用生成Xbm作为验证代码的站点的时候,就相当不方便了,如果有必要,可以通过简单的操作注册表恢复我们需要的功能。
打开注册表(开始---运行---regedit----回车),然后进到键值[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Internet EXPlorer\Security]
将blockXbm的值改为00000000(dword,双字节),没有的话新建立一个就可以了。
之后重新IE或者重新启动机器,则Xbm格式的图片就可以看到了。

五,Xbm的趋势
从SP2禁止Xbm的趋势看出,微软打算似乎已经开始打算放弃对Xbm格式的支持了。那么,作为程序编写者,有必要未雨绸缪,寻找其他生成验证码的途径。在php中,可以通过调用gd库等方式生成jpg/gif等图形格式的注册验证码,那么在asp中有其他的办法么?

事实上图片验证密码的关键是--不能在客户端留下图片的真实url,或可对应反推源地址的信息,因此asp可以采用以下2种方式实现支持SP2的图形验证码。

如果是购买的虚拟主机,那么可以采用将jpg/gif图片放到数据库,然后用session传值的方式,最后利用asp直接从数据库中输出图片,这方法的好处是不需要特别设置服务器端,坏处则是每次生成验证图片时都会需要与数据库连接,增加了开销。

没有任何要求,填对进行。

没有要求,直接照着输就行了,不分大小写


静态网页与动态网页的区别
动态网页:以asp、jsp、php、perl、cgi等形式为后缀,并且在动态网页网址中有一个标志性的符号问号?静态网页:以htm、html、shtml、xml等形式为后缀。2、程序语言不同 动态网页使用语言HTML+ASP或HTML+PHP或HTML+JSP等。静态网页使用语言HTML(超文本标记语言)。3、程序是否在服务器端运行:动态网页...

怎样确定网站所选用的服务器端技术,是ASP,JSP还是PHP?
前,最常用的三种动态网页语言有ASP(Active Server Pages),JSP(JavaServer Pages),PHP (Hypertext Preprocessor)。 简介: ASP全名Active Server Pages,是一个WEB服务器端的开发环境,利用它可以产生和执行动态的、互动的、高性能的WEB服务应用程序。ASP采用脚本语言VBScript(Java script)作为自己的开发语言。 PHP是...

php 由哪个页面
PHP是由服务器端的脚本文件实现的。该文件通常被称为PHP文件,通常以“.php”为后缀名。它们是网页上的代码,用于动态生成网页内容。当用户在浏览器中请求一个包含PHP代码的网页时,服务器会解析并执行这些PHP代码,然后将结果发送到用户的浏览器,用户就能看到动态生成的网页内容。PHP代码可以在不同的...

网页制作中ASP是什么?
ASP的网页文件的格式是.asp,现在常用于各种动态网站中。 ASP是一种服务器端脚本编写环境,可以用来创建和运行动态网页或web应用程序。ASP网页可以包含HTML标记、普通文本、脚本命令以及COM组件等。利用ASP可以向网页中添加交互式内容(如在线表单),也可以创建使用HTML网页作为用户界面的web应用程序。 与...

打开个别网页显示:“\/”应用程序中的服务器错误
两种情况:1是当前访问人数过多,造成服务器暂时性崩溃,这种情况下过一会在上或者刷新几次就好了。第二种情况就是该网页不存在,网址指向错误。

网站开发中的前端后端分别指什么
大家熟知的Facebook就是Web前端技术的产物,完全基于前端框架打造出来的平台。另外,外卖平台饿了么旗下的部分产品也是基于Web前端技术的。像淘宝,百度,阿里等等,都已经将Web前端技术打入到了自己的产品中。后端:为了让服务器、应用、数据库能够彼此交互,后端工程师需要具有用于应用构建的服务器端语言,...

怎么在网页中嵌入另一个页面(在服务器端获取的页面)?
<!doctype html>iframe

服务器的iis怎么打开网页服务器的iis怎么打开网页
2、更新完成后,打开浏览器,输入“http:\/\/localhost\/ ”回车,如果此时出现IIS7欢迎界面,说明Web服务器已经搭建成功。3当web服务器搭建成功后,下一步所要做的就是把开发的网站安装到Web服务器的目录中。一般情况下,当Web服务器安装完成后,会创建路径“%系统根目录%inetpub\/wwwroot”,将开发的网站...

服务器和客户端的详细意思
不过客户端及伺服端的关系不见得一定建立在两台分开的机器上,同一台机器中也有这种主从关系的存在。提供服务的伺服端及接受服务的客户端也有可能都在同一台机器上,例如我们在提供网页的服务器上执行浏览器浏览本机所提供的网页,这样在同一台机器上就同时扮演伺服端及客户端 ...

apache服务器端配置文件是
Apache服务器端的主要配置文件是httpd.conf。Apache HTTP服务器,通常被简称为Apache,是一款开源的、跨平台的网页服务器软件。它可以运行在几乎所有的计算机操作系统上,并且是互联网上最流行的web服务器软件之一。Apache服务器的配置文件是用于调整服务器行为和性能的文本文件,其中包括了许多不同的设置和...

乐亭县19287997497: 请问一下网页中验证码是如何实现的 -
守戚卓威: 你好!应该对你有帮助的!验证码一般是服务器端生成的图片,在服务端用Session记下字符串 然后客户端将所填的字符串提交到服务端与Session记下字符串进行对比.望采纳.

乐亭县19287997497: 网页上的图片验证码是如何实现的
守戚卓威: jsp实现图片验证码的方法 调用方法<img src="https://img.sogoucdn.com/v2/thumb/?appid=200698&url=http%3A%2F%2Fwww.31km.cn%2FgetImg"> 原理,在servlet中随机生成一个4位数字1000-9999然后把这数字写入session输出一个图...

乐亭县19287997497: 在Javaweb中,我用一个jsp页面生成一个验证码图片并用session保存图片上的数字,然后又 -
守戚卓威: 为什么要放在session.太浪费资源.放在request里面.每次请求的时候后台生成一个新的数字就request.setAttribult,页面getAtrribult就可以了.你百度下用法就懂了

乐亭县19287997497: 如何得到验证码图片地址? -
守戚卓威: 是的,那个verifyCodeImg.jsp就是用来动态图片的程序,它是一个普通的动态网页,但是当你访问这个地址的时候,它就会更改网页头部信息,同时生成图像,传给你的浏览器,你的浏览器就会把它做一个普通图片来打开,在这个过程中,并没有真实的服务器上的图片地址给你的. 要有兴趣测试的话,随便去下载一个asp验证码源码,在你机器上用iis或者小型的quickweb之类跑一下就知道了. 验证码图片的地址?如果你指真实的图片地址的话,那个东西一般都是动态生成的,它并没有真正的图片地址,也就是你在网页源码中看到的那个链接地址就是是它的地址,比如象code.php?2938493894这种就是

乐亭县19287997497: 验证码应该怎样验证才能够起到验证码的作用? -
守戚卓威: 服务器端随机生成验证码字符串,保存在内存中,并写入图片,发送给浏览器端显示,浏览器端输入验证码图片上字符,然后提交服务器端,提交的字符和服务器端保存的该字符比较是否一致.一致就继续,否则返回提示.攻击者编写的robot程序,很难识别验证码字符,顺利的完成自动注册,登录.........而用户可以识别填写,所以这就实现了阻挡攻击的作用.而图片的字符识别,就是看图片上的干扰强度了.就实际的效果来说,验证码只是增加攻击者的难度,而不可能完全的防止.

乐亭县19287997497: 网页制作:网页中登录时出现的验证是怎么实现的(如图)?求详细步骤?谢谢 -
守戚卓威: 有两种方式: 1.纯粹的前台Javascript生成:1.1.将需要用到的数字,字母图片都放置在服务器图片 文件夹中,命名最好对应图片;1.2.使用js随机函数,随机从24个字母和0-9种抽取四个字符;1.3.从js随机函数生成的随机4字符中,对应匹配...

乐亭县19287997497: 用html做的一个form+table注册页面里有一个验证码,要怎么写这个js代码?? -
守戚卓威: 可以用JS做个简单的验证码 <script language="javascript">var code; //在全局 定义验证码 function createCode() { //创建验证码函数code = "";var codeLength =5;//验证码的长度var selectChar = new Array(0,1,2,3,4,5,6,7,8,9,'A','B','C','...

乐亭县19287997497: 网站验证码一般放在服务器端什么地方 -
守戚卓威: 简单点说,验证码生成的时候,先生成随机字符串,这个变量以session的形式存储在服务器内存中,与客户端session-id对应,然后使用GDI+等绘图方式绘制成图片然后输出到页面上,服务端不保存图片只记录字符串用于验证

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网