怎样用java实现验证码

Python020

怎样用java实现验证码,第1张

现在许多系统的注册 登录或者发布信息模块都添加的随机验证码功能 就是为了避免自动注册程序或者自动发布程序的使用

验证码实际上就是随机选择一些字符以图片的形式展现在页面上 如果进行提交操作的同时需要将图片上的字符同时提交 如果提交的字符与服务器session保存的不同 则认为提交信息无效 为了避免自动程序分析解析图片 通常会在图片上随机生成一些干扰线或者将字符进行扭曲 增加自动识别验证码的难度

在这里 我们使用java实现验证码

<%@ page contentType= image/jpeg import= java awt * java awt image * java util * javax imageio * %>

<%!

Color getRandColor(int fc int bc){//给定范围获得随机颜色

Random random = new Random()

if(fc>) fc=

if(bc>) bc=

int r=fc+random nextInt(bc fc)

int g=fc+random nextInt(bc fc)

int b=fc+random nextInt(bc fc)

return new Color(r g b)

}

%>

<%

//设置页面不缓存

response setHeader( Pragma No cache )

response setHeader( Cache Control no cache )

response setDateHeader( Expires )

// 在内存中创建图象

int width= height=

BufferedImage image = new BufferedImage(width height BufferedImage TYPE_INT_RGB)

// 获取图形上下文

Graphics g = image getGraphics()

//生成随机类

Random random = new Random()

// 设定背景色

g setColor(getRandColor( ))

g fillRect( width height)

//设定字体

g setFont(new Font( Times New Roman Font PLAIN ))

// 随机产生 条干扰线 使图象中的认证码不易被其它程序探测到

g setColor(getRandColor( ))

for (int i= i<i++)

{

int x = random nextInt(width)

int y = random nextInt(height)

int xl = random nextInt( )

int yl = random nextInt( )

g drawLine(x y x+xl y+yl)

}

// 取随机产生的认证码( 位数字)

String codeList = ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz

String sRand=

for (int i= i<i++){

int a=random nextInt(codeList length() )

String rand=codeList substring(a a+ )

sRand+=rand

// 将认证码显示到图象中

g setColor(new Color( +random nextInt( ) +random nextInt( ) +random nextInt( )))//调用函数出来的颜色相同 可能是因为种子太接近 所以只能直接生成

g drawString(rand *i+ )

}

// 将认证码存入SESSION

session setAttribute( rand sRand)

// 图象生效

g dispose()

// 输出图象到页面

ImageIO write(image JPEG response getOutputStream())

out clear()

out = pageContext pushBody()

lishixinzhi/Article/program/Java/hx/201311/25536

原理,在servlet中随机生成一个4位数字1000-9999

然后把这数字写入session

输出一个图片,上面写有这四个数字

在服务器端根据用户输入的数字和

session中的值比较。

注意比较结束后要清空session中的值

有很多人问到验证码的作用。

我作个简单的解释。

验证码的作用:有效防止这种问题对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试,实际上是用验证码是现在很多网站通行的方式(比如招商银行的网上个人银行,腾讯的QQ社区),我们利用比较简易的方式实现了这个功能。虽然登陆麻烦一点,但是对社区还来说这个功能还是很有必要,也很重要。但我们还是提醒大家主要保护自己的密码,尽量使用混杂了数字、字母、符号在内的6位以上密码,不要使用诸如1234之类的简单密码或者与用户名相同、类似的密码。

还有就是注册时发表文章时加验证码,就防人用注册机,无限的自动注册,

package com.schoolwx.util

import java.io.*

import java.util.*

import com.sun.image.codec.jpeg.*

import javax.servlet.*

import javax.servlet.http.*

import java.awt.*

import java.awt.image.*

public class getImg extends HttpServlet {

private Font mFont=new Font("宋体", Font.PLAIN,12)//设置字体

//处理post

public void doPost(HttpServletRequest request,HttpServletResponse response)

throws ServletException,IOException {

doGet(request,response)

}

public void doGet(HttpServletRequest request,HttpServletResponse response)

throws ServletException,IOException {

//取得一个1000-9999的随机数

String s=""

int intCount=0

intCount=(new Random()).nextInt(9999)//

if(intCount<1000)intCount+=1000

s=intCount+""

//对session付值。

HttpSession session=request.getSession (true)

session.setAttribute("getImg",s)

response.setContentType("image/gif")

ServletOutputStream out=response.getOutputStream()

BufferedImage image=new BufferedImage(35,14,BufferedImage.TYPE_INT_RGB)

Graphics gra=image.getGraphics()

//设置背景色

gra.setColor(Color.yellow)

gra.fillRect(1,1,33,12)

//设置字体色

gra.setColor(Color.black)

gra.setFont(mFont)

//输出数字

char c

for(int i=0i<4i++) {

c=s.charAt(i)

gra.drawString(c+"",i*7+4,11)//7为宽度,11为上下高度位置

}

JPEGImageEncoder encoder=JPEGCodec.createJPEGEncoder(out)

encoder.encode(image)

out.close()

}

}

package com.he

import javax.servlet.*

import javax.servlet.http.*

import java.io.*

import java.util.*

import java.awt.*

import java.awt.image.*

import javax.imageio.*

public class CodeFact

extends HttpServlet {

public void doGet(HttpServletRequest request, HttpServletResponse response) throws

ServletException, IOException {

//设置页面不缓存

response.setHeader("Pragma", "No-cache")

response.setHeader("Cache-Control", "no-cache")

response.setDateHeader("Expires", 0)

// 在内存中创建图象

int width = 60, height = 20

BufferedImage image = new BufferedImage(width, height,

BufferedImage.TYPE_INT_RGB)

// 获取图形上下文

Graphics g = image.getGraphics()

//生成随机类

Random random = new Random()

// 设定背景色

g.setColor(getRandColor(200, 250))

g.fillRect(0, 0, width, height)

//设定字体

g.setFont(new Font("Times New Roman", Font.PLAIN, 18))

//画边框

g.setColor(new Color(33,66,99))

g.drawRect(0,0,width-1,height-1)

// 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到

g.setColor(getRandColor(160, 200))

for (int i = 0i <155i++) {

int x = random.nextInt(width)

int y = random.nextInt(height)

int xl = random.nextInt(12)

int yl = random.nextInt(12)

g.drawLine(x, y, x + xl, y + yl)

}

// 取随机产生的认证码(4位数字)

String sRand = ""

for (int i = 0i <4i++) {

String rand = String.valueOf(random.nextInt(10))

sRand += rand

// 将认证码显示到图象中

g.setColor(new Color(20 + random.nextInt(110), 20 + random.nextInt(110),

20 + random.nextInt(110)))//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成

g.drawString(rand, 13 * i + 6, 16)

}

// 将认证码存入SESSION

HttpSession session = request.getSession()

session.setAttribute("rand", sRand)

// 图象生效

g.dispose()

// 输出图象到页面

ImageIO.write(image, "JPEG", response.getOutputStream())

}

public void doPost(HttpServletRequest request, HttpServletResponse response) throws

ServletException, IOException {

doGet(request, response)

}

//给定范围获得随机颜色

private Color getRandColor(int fc, int bc) {

Random random = new Random()

if (fc >255) {

fc = 255

}

if (bc >255) {

bc = 255

}

int r = fc + random.nextInt(bc - fc)

int g = fc + random.nextInt(bc - fc)

int b = fc + random.nextInt(bc - fc)

return new Color(r, g, b)

}

}

你试试!!