用JSP实现图形验证码

js|图形|验证码

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 ValidateCode  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,用于与用户的输入进行比较.
  //注意比较完之后清除session.

  HttpSession session=request.getSession (true);

  session.setAttribute("validateCode",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=0;i<4;i++) {

  c=s.charAt(i);

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

  }

  JPEGImageEncoder encoder=JPEGCodec.createJPEGEncoder(out);

  encoder.encode(image);

  out.close();

  }
}

  java的图片处理包需要图形环境,而linux上没有启动图形环境,找不到图形环境的server(X11 window server using ':0.0' )所以会报这个错。而通过java -Djava.awt.headless=true 这个参数的指定就可以避免java 2d去找图形环境。

  要么这样试试,应该也可以。在servlet里一开始写一句:

System.setProperty("java.awt.headless","true");

  web服务器的java虚拟机必须加以个参数java.awt.headless=true

  以tomcat为例

  可以在/etc/profile或启动web服务的用户的.bash_profile中的CATALINA_OPTS变量中加入:

CATALINA_OPTS="... -Djava.awt.headless=true"

  其他的也可以看看启动脚本。只要加上这个参数就没问题了。

时间: 2025-01-31 05:31:11

用JSP实现图形验证码的相关文章

JSP实现图形验证码-汉字

js|汉字|图形|验证码 <%@page contentType="image/jpeg" import="java.awt.*,java.awt.image.*,java.util.*,javax.imageio.*"%> <%!  //create by smallnest  //email: smallnest@gmail.com  //website:www.kuaff.com  //生成随机颜色  Color getRandColor(R

技巧实例:jsp实现图形验证码

js|技巧|图形|验证码   调用方法       <img   src="http://...../getImg">           原理,在servlet中随机生成一个4位数字1000-9999然后把这数字写入session输出一个图片,上面写有这四个数字在服务器端根据用户输入的数字和 session中的值比较.   package   com.schoolwx.util;       import   java.io.*;       import   java.

Java Web开发之图形验证码的生成与使用方法_JSP编程

本文实例讲述了Java Web开发之图形验证码的生成与使用方法.分享给大家供大家参考.具体如下: 图形验证码的主要目的是为了增强的安全性,增加用户通过遍历所有可能性来破解密码的难度. 图形验证码的使用包括如下3部分: ① 图形验证码的生成: ② 在页面中的使用: ③ 验证: 1.图形验证码的生成 假设在Servlet生成图形验证码,在JavaBean或者JSP中生成的基本过程是相同的.设计如下过程: ① 设置响应的文档类型: ② 生成随机码: ③ 把随机码保存到session中: ④ 生成图片:

自己写的一个图形验证码页面(Asp.Net2.0通过)

asp.net|图形|验证码|页面 项目需要,要在首页登录界面添加一个图形验证码,赶时髦吧,网上一搜,特别多,找了几个,都不太满意.主要问题是大部分代码生成的图片宽度不唯一,页面布局不容易控制,其次是颜色单一,有些又过于抽象,不仔细看很容易弄错.针对特定的客户,我只需要"图片"长宽固定,颜色多样的数字图形验证码,借鉴网上的现有代码,自己操刀完成,以下是效果图: 原理不复杂,就是把网页当画布,运用各色画笔,在特定区域内画出数字,然后以特定格式(本例为PNG格式)发回客户端,在IE中显示为

Jsp实现图片验证码的技巧

图片验证码的实现主要的技术点是如何生成一个图片.生成图片可以使用java.awt包下的类来实现.我们先写一个简单的生成图片的程序HelloImage.java.以下是代码部分. package com.vogoal.test;import java.awt.Color;import java.awt.Graphics;import java.awt.image.BufferedImage;import java.io.File;import java.io.IOException;import

使用Asp.Net 2.0编写的图形验证码页面

项目需要,要在首页登录界面添加一个图形验证码,赶时髦吧,网上一搜, 特别多,找了几个,都不太满意.主要问题是大部分代码生成的图片宽度不唯一 ,页面布局不容易控制,其次是颜色单一,有些又过于抽象,不仔细看很容易弄 错.针对特定的客户,我只需要"图片"长宽固定,颜色多样的数字图形验证码 ,借鉴网上的现有代码,自己操刀完成,以下是效果图: 原理不复杂,就是把网页当画布,运用各色画笔,在特定区域内画出数字, 然后以特定格式(本例为PNG格式)发回客户端,在IE中显示为"图片"

PHP5中GD库生成图形验证码(有汉字)

本文为大家介绍下利用PHP5中GD库生成图形验证码而且带有汉字,具体的实现思路及代码如下,有需求的朋友可以参考下,希望对大家学习php有所帮助   利用PHP5中GD库生成图形验证码   类似于下面这样 1.利用GD库函数生成图片,并在图片上写指定字符 imagecreatetruecolor 新建一个真彩色图像 imagecolorallocate 为一幅图像分配颜色(调色板) imagestring 绘制字符 imageline 绘制线条 imagesetpixel 打像素点 2.输出图片

图形验证码最佳攻略2

下面是注册 如果是手机用户注册,需要发送短信验证码  说明: 发送图形验证码是为了拦截发送短信的.但是不拦截"注册帐号" 但是,用户体验很别扭,因为图形验证码很显然是错误的,但是却可以注册成功.  如果点击注册帐号 ,也要校验图形验证码,那就让用户输入两次图形验证码,显然不是很人性化 注意:注册时发送短信每次都需要输入图形验证码,而不是发送3次短信才要输入. 那么如何解决这个问题呢? 把注册拆分为两步: 第一步:发送短信验证码     第二步:设置密码和用户名   这样达到的目的: (

Web 图形验证码的校验1

网站开发中,就会经常涉及到图形验证码的校验,比如: 那么如何校验呢? 我们原来的校验方式:前后端都校验 步骤: (1)前端js 校验图形验证码的MD5 (2)校验通过才真正发送请求到服务器; (3)服务器再次校验图形验证码明文 注意:前端js校验的不是图形验证码明文,而是其MD5值;   如何获取图形验证码的MD5值呢? 服务器需要提供一个单独的接口,返回当前图形验证码的MD5.什么叫"当前"? 就是从session或redis中获取一个图形验证码,而不是重新生成.   后来我们修改了