一,Servlet生成图片验证码

第一步:创建一个生成图片的ImageServlet类

package com.lmc.servlet;import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;public class ImageServlet extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doPost(request,response);}
}

第二步:创建一个数据缓存图像对象

//其中width表示图像的宽度,height表示图像的高度,最后一个参数表示图像字节灰度图像
BufferedImage  b = new BufferedImage(width, height, BufferedImage.TYPE_BYTE_GRAY);

第三步:获取BufferedImage的绘制对象,再设置一些属性

//获取BufferedImage的绘制对象
Graphics g = b.getGraphics();
//绘制干扰线
for (int i = 0;i < 5; i++){int x1 = random.nextInt(59);int y1 = random.nextInt(29);int x2 = random.nextInt(59);int y2 = random.nextInt(29);g.drawLine(x1,y1,x2,y2);
}
// 设置画笔的一些属性(比如颜色、字体风格、背景、前景色等等)

第四步:创建一个图片验证的jsp页面

<%--Created by IntelliJ IDEA.User: AdministratorDate: 19/7/26Time: 14:00To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>Title</title>
</head>
<body>
<h1>图片验证</h1><img  width="60px" height="30px" οnclick="changeImage(this)">
</body>
<script>window.onload = function () {document.getElementsByTagName("img")[0].src = "/lmc/image.do?time="+ new Date().getTime();;}function changeImage(e) {e.src = "/lmc/image.do?time="+ new Date().getTime();}
</script>
</html>

代码:

package com.lmc.servlet;import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;public class ImageServlet extends HttpServlet {protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {response.setContentType("text/html;charset=utf-8");//创建一个数据缓存图像对象BufferedImage b = new BufferedImage (60, 30, BufferedImage.TYPE_BYTE_GRAY);//创建字符源String charSourses = "abcdefghijklmnopqrstuvwxyz0123456789";String numStr = "";Random random = new Random();for (int i = 0;i < 4; i++){int num = random.nextInt(charSourses.length() - 1);numStr += charSourses.substring(num,num+1);}//获取BufferedImage的绘制对象Graphics g = b.getGraphics();//绘制干扰线for (int i = 0;i < 5; i++){int x1 = random.nextInt(59);int y1 = random.nextInt(29);int x2 = random.nextInt(59);int y2 = random.nextInt(29);g.drawLine(x1,y1,x2,y2);}// 设置画笔的一些属性(比如颜色、字体风格、背景、前景色等等)g.drawString(numStr, 12, 19);request.getSession().setAttribute("checkCode",numStr);ImageIO.write(b, "jpg",response.getOutputStream());}protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doPost(request,response);}
}

二,使用Kaptcha插件生成验证码

1. 导入相应的jar包

​ kaptcha-2.3.jar

2. 写一个生成验证码图片的servlet

package com.eight.servlet;import com.google.code.kaptcha.Producer;
import com.google.code.kaptcha.util.Config;import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Enumeration;
import java.util.Properties;
import java.util.Random;import javax.imageio.ImageIO;
import javax.servlet.Servlet;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;public class KaptchaServlet extends HttpServlet implements Servlet {private Properties props;private Producer kaptchaProducer;private String sessionKeyValue;public KaptchaServlet() {this.props = new Properties();this.kaptchaProducer = null;this.sessionKeyValue = null;}public void init(ServletConfig conf) throws ServletException {super.init(conf);ImageIO.setUseCache(false);Enumeration initParams = conf.getInitParameterNames();while (initParams.hasMoreElements()) {String key = (String) initParams.nextElement();String value = conf.getInitParameter(key);this.props.put(key, value);}Config config = new Config(this.props);this.kaptchaProducer = config.getProducerImpl();this.sessionKeyValue = config.getSessionKey();}public void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {resp.setDateHeader("Expires", 0L);resp.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");resp.addHeader("Cache-Control", "post-check=0, pre-check=0");resp.setHeader("Pragma", "no-cache");resp.setContentType("image/jpeg");String capText = this.kaptchaProducer.createText();String s1 = capText.substring(0, 1);String s2 = capText.substring(1, 2);String culs = "+-*";Random random = new Random();char cul = culs.charAt(random.nextInt(3));int r = 0;switch(cul){case '+':r = Integer.valueOf(s1).intValue() + Integer.valueOf(s2).intValue();break;case '-':r = Integer.valueOf(s1).intValue() - Integer.valueOf(s2).intValue();break;case '*':r = Integer.valueOf(s1).intValue() * Integer.valueOf(s2).intValue();break;}req.getSession().setAttribute(this.sessionKeyValue, String.valueOf(r));BufferedImage bi = this.kaptchaProducer.createImage(s1 + cul + s2 + "=?");ServletOutputStream out = resp.getOutputStream();ImageIO.write(bi, "jpg", out);try {out.flush();} finally {out.close();}}
}

第三步:在web.xml上配置一些信息

<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1"><!--   登陆验证码Kaptcha 2  --><servlet><servlet-name>Kaptcha</servlet-name><servlet-class>com.eight.servlet.KaptchaServlet</servlet-class><init-param><description>图片边框,合法值:yes , no</description><param-name>kaptcha.border</param-name><param-value>yes</param-value></init-param><init-param><description>边框颜色,合法值: r,g,b (and optional alpha) 或者 white,black,blue.</description><param-name>kaptcha.border.color</param-name><param-value>black</param-value></init-param><init-param><description>边框厚度,合法值:>0</description><param-name>kaptcha.border.thickness</param-name><param-value>1</param-value></init-param><init-param><description>图片宽 200</description><param-name>kaptcha.image.width</param-name><param-value>200</param-value></init-param><init-param><description>图片高 50</description><param-name>kaptcha.image.height</param-name><param-value>50</param-value></init-param><init-param><description>图片实现类</description><param-name>kaptcha.producer.impl</param-name><param-value> com.google.code.kaptcha.impl.DefaultKaptcha </param-value></init-param><init-param><description>文本实现类</description><param-name>kaptcha.textproducer.impl</param-name><param-value>com.google.code.kaptcha.text.impl.DefaultTextCreator</param-value></init-param><init-param><description>文本集合,验证码值从此集合中获取</description><param-name>kaptcha.textproducer.char.string</param-name><param-value>1234567890</param-value></init-param><init-param><description>验证码长度 5</description><param-name>kaptcha.textproducer.char.length</param-name><param-value>2</param-value></init-param><init-param><description>字体 Arial, Courier</description><param-name>kaptcha.textproducer.font.names</param-name><param-value>Arial, Courier</param-value></init-param><init-param><description>字体大小 40px.</description><param-name>kaptcha.textproducer.font.size</param-name><param-value>40</param-value></init-param><init-param><description> 字体颜色,合法值: r,g,b 或者 white,black,blue. </description><param-name>kaptcha.textproducer.font.color</param-name><param-value>black</param-value></init-param><init-param><description>文字间隔 2</description><param-name>kaptcha.textproducer.char.space</param-name><param-value>2</param-value></init-param><init-param><description>干扰实现类</description><param-name>kaptcha.noise.impl</param-name><param-value><!--   com.google.code.kaptcha.impl.NoNoise   -->com.google.code.kaptcha.impl.DefaultNoise</param-value></init-param><init-param><description> 干扰颜色,合法值: r,g,b 或者 white,black,blue. </description><param-name>kaptcha.noise.color</param-name><param-value>black</param-value></init-param><init-param><description>图片样式: 水纹com.google.code.kaptcha.impl.WaterRipple 鱼眼com.google.code.kaptcha.impl.FishEyeGimpy 阴影com.google.code.kaptcha.impl.ShadowGimpy</description><param-name>kaptcha.obscurificator.impl</param-name><param-value> com.google.code.kaptcha.impl.WaterRipple </param-value></init-param><init-param><description>背景实现类</description><param-name>kaptcha.background.impl</param-name><param-value> com.google.code.kaptcha.impl.DefaultBackground </param-value></init-param><init-param><description>背景颜色渐变,开始颜色</description><param-name>kaptcha.background.clear.from</param-name><param-value>green</param-value></init-param><init-param><description>背景颜色渐变,结束颜色</description><param-name>kaptcha.background.clear.to</param-name><param-value>white</param-value></init-param><init-param><description>文字渲染器</description><param-name>kaptcha.word.impl</param-name><param-value>com.google.code.kaptcha.text.impl.DefaultWordRenderer</param-value></init-param><init-param><description> session中存放验证码的key键 </description><param-name>kaptcha.session.key</param-name><param-value>KAPTCHA_SESSION_KEY</param-value></init-param><init-param><description>The date the kaptcha is generated is put into the HttpSession. This is the key value for that item in the session.</description><param-name>kaptcha.session.date</param-name><param-value>KAPTCHA_SESSION_DATE</param-value></init-param></servlet><servlet-mapping><servlet-name>Kaptcha</servlet-name><url-pattern>/randomcode.jpg</url-pattern></servlet-mapping>
</web-app>

3. 在jsp页面写入验证码图片标签和相关js

<script type="text/javascript">function changeR(node){// 用于点击时产生不同的验证码node.src = "randomcode.jpg?time="+new Date().getTime() ; }
</script>
<img style="width:150px;height:35px;vertical-align:top;cursor: pointer;" alt="random" src="randomcode.jpg" οnclick="changeR(this)" />
<input style="width:140px;height:35px;background-color:#e0e6ef;" class="imageCode" name="imageCode" placeholder="请输入验证码" />

4. 在登录验证的servlet中判断验证码是否正确

 //验证码验证private void codeCheck(HttpServletRequest request,HttpServletResponse response) throws IOException {//创建一个json对象JSONObject json = new JSONObject();//获取图片验证码上面的数据String code = (String) request.getSession().getAttribute(com.google.code.kaptcha.Constants.KAPTCHA_SESSION_KEY);//获取用户输入的验证码数据String str = request.getParameter("imageCode");System.out.println(code+"  "+str);if(code.equals(str)){json.put("status","true");}else {json.put("status","error");}PrintWriter out = response.getWriter();   out.print(json); out.flush();out.close();}

JSP——(图片验证码)相关推荐

  1. Spring Boot整合Shiro + JSP教程(用户认证,权限管理,图片验证码)

    在此首先感谢**编程不良人**up主提供的视频教程 代码都是跟着up的视频敲的,遇到的一些问题也是通过CSDN博主提供的教程解决的,在此也感谢那些提供bug解决方案的前辈们~ 项目完整代码已经发布到g ...

  2. 图片验证码+输入立即校验

    最近做到登录需要图片验证,很多图片验证都是在后台直接验证不满足我的需求.我需要做到输入密码后就立刻检验出密码的正确还是不是正确,这样提高了用户体验. 这就用到了ajax的内容!记录一下还是挺开心的~ ...

  3. 用开源组件jcaptcha做jsp彩色验证码

    用开源组件jcaptcha做jsp彩色验证码 key words: jsp验证码 jcaptcha 原文参考 这里 安装 Add jcaptcha-all.jar (provided in bin-d ...

  4. Shiro安全框架(Shiro与SpringBoot整合开发)之图片验证码(五)

    这篇博文主要讲解实现图片验证码的实现,之前已经将权限,认证,自带缓存,redis缓存,都实现了,现在我们就来了解一下简单的图片验证码的实现: 首先,我们要来修改一下登录的页面,login.jsp这个页 ...

  5. 登录功能图片验证码的实现

    首先从网上下载一个生成验证码的Servlet: package com.train.controller;import java.awt.Color; import java.awt.Font; im ...

  6. 手机验证码、图片验证码的实现

    手机验证码 第一步:网上找一个第三方短信接口平台,大多数这样的平台都会有免费试用的通知短信.我这里用的是秒滴科技,注册个账号,赠送200条短信,足够项目练手使用了. 第二步:去用户中心查看TOKEN( ...

  7. LoadRunner录制图片验证码

    LoadRunner录制图片验证码 LoadRunner自身是无法捕获到图片验证码的,但是我们可以帮助LoadRunner来实现验证码的捕获. 1.图片验证码 图片验证码的产生来自服务器端,由服务器生 ...

  8. 仿12306验证码 java_仿12306的图片验证码

    由于要做一个新项目,所以打算做一个简单的图片验证码. 先说说思路吧:在服务端,从一个文件夹里面找出8张图片,再把8张图片合并成一张大图,在8个小图里面随机生成一个要用户验证的图片分类,如小狗.啤酒等. ...

  9. 【java图片验证码】Java 服务端生成图片验证码及验证

    Java 服务端生成图片验证码及验证 简介 验证码是防止有人利用机器人自动批量注册.对特定的注册用户用特定程序暴力破解方 式进行不断的登录.灌水.因为验证码是一个混合了数字或符号的图片,人眼看起来都费 ...

  10. SSM 实训笔记 -10- 使用 sessionStorage 存储数据、js 图片验证码、登录加载动画

    SSM 实训笔记 -10- 使用 sessionStorage 存储数据.js 图片验证码.登录加载动画 本篇内容: (1)在登录成功时,使用 sessionStorage 存储用户的用户名,并在登录 ...

最新文章

  1. iptables 流量速率控制
  2. CF1101D GCD Counting
  3. caffe 一些网络参数
  4. VSCode 启动 Vue 项目 npm install 报错
  5. 源码详解Java的反射机制
  6. iPhone垃圾信息被骂惨了,苹果一拍脑门:上机器学习呀
  7. java连接oracle数据库jdbc
  8. php curl 请求失败,PHP CURL库之GET、POST数据大小限制导致请求失败解决方案
  9. 【转】请求处理机制其二:Django中间件的解析
  10. Xshell正版免费,再也不用找破解版了!
  11. 随机森林算法原理简要总结
  12. coalesce函数详解--判空三目表达式
  13. Profinet 与 EtherCAT 网关使用方法
  14. 云电脑服务:技术与商业模式双重创新
  15. iguana::json/xml 序列化框架
  16. Docker容器化开发流程(一)介绍
  17. apple 密码 seeion has time out 无法再本机上重设密码
  18. Echarts 坐标轴刻度间隔/全部显示
  19. js逆向--有道翻译
  20. 设计模式学习(八) 模板方法模式

热门文章

  1. struts2拦截器原理
  2. 对话框ModifyStyle(0, WS_MINIMIZEBOX)最小化按钮无效的解决方法
  3. 小米与乐视的竞争分析
  4. SharePoint下载大文件失败 异常信息: system.OutOfMemoryException
  5. OSX: Mac不睡眠的排查
  6. android6.0 framework修改使用两个声卡
  7. Modbus转Profinet网关与ARX-MA100微型空气质量监测系统配置案例
  8. 解决C:/WINDOWS/system32/aliedit/a找不到文件的错误提示
  9. 淘宝的npaliedit在mb下会崩溃的问题解决了
  10. 中班音乐计算机反思,幼儿园音乐活动反思10篇