jsp验证码实现代码

1.后台java代码

package com.bobo.base.servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * <p>Title:用于产生校验码的servlet类</p>
 * <p>Description: 用于产生校验码的servlet类</p>
 * @author  
 * @version 1.0 2010-09-05
 */

@SuppressWarnings("serial")
public class CheckCodeServlet 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());
    //g.drawRect(0, 0, width - 1, height - 1);


    // 随机产生155条干扰线,使图象中的认证码不易被其它程序探测到
    g.setColor(getRandColor(160, 200));
    for (int i = 0; i < 155; i++) {
        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 = 0;i < 4; i++) {
        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
    request.getSession().setAttribute("checkCode", sRand);

    // 图象生效
    g.dispose();

    // 输出图象到页面
    ImageIO.write(image, "JPEG", response.getOutputStream());
}
 /**
  * 获取随机颜色
  * @param fc
  * @param bc
  * @return
  */	
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);
	}


}

2.web.xml配置

<servlet>
    <servlet-name>checkCodeServlet</servlet-name>
    <servlet-class>com.bobo.base.servlet.CheckCodeServlet</servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>checkCodeServlet</servlet-name>
    <url-pattern>/checkCode.jpg</url-pattern>
  </servlet-mapping>

3.jsp页面调用

 <tr>
        <th>验证码:</th>
	<td><input  id="checkCode" name="checkCode" size="30" maxlength="6" type="text" value="" style="ime-mode:disabled"/><img src='checkCode.jpg' class="code" /></td> 
</tr>

4.java验证代码:

session中拿到checkCode的值与jsp页面传入的值checkCode进行比较。


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现 JSP 登录验证码,可以按照以下步骤进行: 1. 在 JSP 页面中添加验证码的显示位置。可以使用 HTML 的 `<img>` 标签来显示验证码图片。 2. 在后台生成验证码图片。可以使用 Java 的 BufferedImage 类来生成图片,然后使用 ImageIO 将其写入输出流中。 3. 将验证码字符串保存到 session 中,以便后续验证时使用。 4. 在用户提交登录表单时,获取用户输入的验证码字符串并与 session 中保存的验证码进行比较。如果一致,则允许用户进行登录操作;否则提示用户验证码输入有误并刷新验证码。 下面是一个简单的示例代码: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ page import="java.awt.Color"%> <%@ page import="java.awt.Font"%> <%@ page import="java.awt.Graphics"%> <%@ page import="java.awt.image.BufferedImage"%> <%@ page import="java.util.Random"%> <% // 生成随机验证码字符串 String code = ""; Random random = new Random(); for (int i = 0; i < 4; i++) { code += (char) (random.nextInt(26) + 'A'); } // 将验证码保存到 session 中 session.setAttribute("code", code); // 生成验证码图片 int width = 100; int height = 40; BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics g = image.getGraphics(); g.setColor(Color.WHITE); g.fillRect(0, 0, width, height); g.setFont(new Font("Arial", Font.BOLD, 20)); for (int i = 0; i < 4; i++) { g.setColor(new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256))); g.drawString(code.substring(i, i + 1), i * 20 + 10, 25); } for (int i = 0; i < 10; i++) { g.setColor(new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256))); g.drawLine(random.nextInt(width), random.nextInt(height), random.nextInt(width), random.nextInt(height)); } // 输出验证码图片 response.setContentType("image/jpeg"); ImageIO.write(image, "jpeg", response.getOutputStream()); %> 在 JSP 页面中可以使用以下代码来显示验证码图片: <img src="captcha.jsp" /> 其中 "captcha.jsp" 是上面生成验证码图片的 JSP 页面的路径。用户提交登录表单时,可以使用以下代码来获取用户输入的验证码字符串并与 session 中保存的验证码进行比较: String code = request.getParameter("code"); String captcha = (String) request.getSession().getAttribute("code"); if (code.equalsIgnoreCase(captcha)) { // 验证码输入正确,允许用户登录 } else { // 验证码输入有误,提示用户并刷新验证码 }
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值