简单验证码实现(jsp)

页面code.jsp
<html>
  <head>
<%!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);
}%>
<%
//设置页面不缓存
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
// 在内存中创建图象
int width = 100, height = 35;
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, 35));
//画边框  //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 randString[] = 
 {
  "1","2","3","4","5",
  "6","7","8","9","0",
"a","b","c","e","f",
"g","h","i","j","k",
"l","m","n","o","p",
"q","r","s","t","u",
"v","w","x","y","z",
};
 String sRand = "";
for (int i = 0; i < 4; i++) {
 String rand = randString[random.nextInt(randString.length)];
 sRand += rand;
// 将认证码显示到图象中
 g.setColor(new Color(20 + random.nextInt(110), 20 + random.nextInt(110), 20 + random.nextInt(110)));
//调用函数出来的颜色相同,可能是因为种子太接近,所以只能直接生成
 g.drawString(rand, 20 * i + 6, 28);
 }
// 将认证码存入SESSION 
 session.setAttribute("rand", sRand);
// 图象生效 
 g.dispose();
// 输出图象到页面  
 ImageIO.write(image, "JPEG", response.getOutputStream());
 out.clear();
 out = pageContext.pushBody();
%>
 <body>
  </body>
</html>


使用
 <img src="code.jsp" border="0" alt="验证码,看不清楚?请点击刷新验证码" οnclick="this.src='code.jsp?  ran='+Math.random()" />
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 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 { // 验证码输入有误,提示用户并刷新验证码 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值