JSP实现验证码

作者:gqk:


 验证码我们可以用javaSE中的GUI去完成:

核心代码:

封装验证码类:

package com.xkrj.yzm;

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.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import javax.swing.JFrame;

public class DrawYzm  extends JFrame{//继承JFrame窗口
	private int width = 900;//验证码宽度
    private int height = 240;//验证码高度
    private int codeCount = 4;//验证码个数
    private int lineCount = 300;//混淆线个数
    
    //定义验证码内容
    char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
            'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
            'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
    	//画验证码
    public 	void getCode(HttpServletRequest request,HttpServletResponse response) throws IOException{
    	//定义随机数类
    	Random r = new Random();
    	//创建StringBulider类拼接验证码
    	StringBuilder builderCode = new StringBuilder();
    	//定义画布
        BufferedImage buffImg = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);	
        //创建画笔
       Graphics g =  buffImg.getGraphics();
       //设置颜色和边框
       g.setColor(Color.black);
       //画矩形
       g.drawRect(0,0,width,height);
       //2.设置颜色,填充内部
       g.setColor(Color.white);
       g.fillRect(1,1,width-2,height-2);
     //3.设置干扰线
       g.setColor(Color.red);

       for (int i = 0; i < lineCount; i++) {
           g.drawLine(r.nextInt(width),r.nextInt(width),r.nextInt(width),r.nextInt(width));
       }
       //4.设置验证码
       g.setColor(Color.blue);
       //4.1设置验证码字体
       g.setFont(new Font("微软雅黑",Font.LAYOUT_LEFT_TO_RIGHT,150));
       for (int i = 0; i < codeCount; i++) {
           char c = codeSequence[r.nextInt(codeSequence.length)];
           builderCode.append(c);
           g.drawString(c+"",150*(i+1),175);
       }
       //5.输出到屏幕
       ServletOutputStream sos = response.getOutputStream();
       ImageIO.write(buffImg,"png",sos);
       //6.保存到session中
       HttpSession session = request.getSession();
       session.setAttribute("codeValidate",builderCode.toString());
       //7.禁止图像缓存。
       response.setHeader("Pragma", "no-cache");
       response.setHeader("Cache-Control", "no-cache");
       response.setDateHeader("Expires", 0);
       response.setContentType("image/png");
       //8.关闭sos
       sos.close();
    	
    }

}

  Servlet中调用:

package com.xkrj.yzm;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/codeServlet")
public class CodeServlet extends HttpServlet {
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		// TODO Auto-generated method stub
		this.doPost(req, resp);
	}
	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
		DrawYzm dy= new DrawYzm();
		dy.getCode(req, resp);
				
	}
}

 

  

可以用ajax进行验证,验证码已经绑定再Session之中,验证比较简单就不写了!

转载于:https://www.cnblogs.com/520gqk/p/9948576.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,你需要在 JSP 页面上添加一个验证码输入框和一个提交按钮,代码如下: ```html <form action="login.jsp" method="post"> <label for="username">用户名:</label> <input type="text" id="username" name="username"><br><br> <label for="password">密码:</label> <input type="password" id="password" name="password"><br><br> <label for="captcha">验证码:</label> <input type="text" id="captcha" name="captcha"><br> <img src="captcha.jsp"><br> <input type="submit" value="登录"> </form> ``` 其中,`captcha.jsp` 是生成验证码JSP 页面,下面会介绍如何编写。 接下来,你需要编写 `login.jsp` 页面,用于验证用户输入的验证码是否正确,代码如下: ```jsp <%@ page contentType="text/html;charset=UTF-8" %> <% String username = request.getParameter("username"); String password = request.getParameter("password"); String captcha = request.getParameter("captcha"); String sessionCaptcha = (String) session.getAttribute("captcha"); if (captcha != null && captcha.equalsIgnoreCase(sessionCaptcha)) { // 验证码正确,可以进行登录操作 // TODO: 在这里编写登录逻辑 out.println("登录成功!"); } else { // 验证码错误,返回登录页面 out.println("验证码错误,请重新输入!"); } %> ``` 在这段代码中,首先获取用户输入的用户名、密码和验证码,然后从 Session 中获取之前生成的验证码,进行比较。如果验证码正确,则可以进行登录操作,否则返回登录页面。 最后,你需要编写 `captcha.jsp` 页面,用于生成验证码图片,代码如下: ```jsp <%@ page contentType="image/jpeg" %> <% // 生成随机字符串 String captcha = ""; Random random = new Random(); for (int i = 0; i < 4; i++) { int value = random.nextInt(10); captcha += String.valueOf(value); } // 将验证码保存到 Session 中 session.setAttribute("captcha", captcha); // 生成验证码图片 BufferedImage image = new BufferedImage(80, 30, BufferedImage.TYPE_INT_RGB); Graphics2D g = image.createGraphics(); g.setColor(Color.WHITE); g.fillRect(0, 0, 80, 30); g.setColor(Color.BLACK); g.setFont(new Font("Arial", Font.BOLD, 20)); g.drawString(captcha, 10, 20); g.dispose(); // 输出图片 ServletOutputStream out = response.getOutputStream(); ImageIO.write(image, "JPEG", out); out.close(); %> ``` 在这段代码中,首先生成一个随机的四位数字字符串作为验证码,并将其保存到 Session 中。然后,使用 Java 的图形库 `BufferedImage` 生成验证码图片,并将其输出。这样,用户每次刷新页面都会生成一个新的验证码

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值