java 生成图片验证码

article/2025/9/20 22:14:27

https://vimsky.com/zh-tw/examples/detail/java-class-javax.servlet.ServletOutputStream.html

开发过程中,需要服务端返回验证码图片给前台,想想该如何实现呢?

1、字节流的输入输出
2、生成一个验证码,自定义字母数字混合实现
3、生成一个图片,可以自定义颜色设置

上代码,看结果。

/*** 生成验证码图片** @return*/public Map<String, Object> generateIdentifyCode(HttpServletRequest request, int width, int height) {Map<String, Object> map = new HashMap<>(2);String uniqueId = this.getUniqueIdFromCookie(request);if (StringUtils.isBlank(uniqueId)) {uniqueId =System.nanoTime() + RandomStringUtils.randomAlphanumeric(10);}int num = Integer.valueOf(codeLength);//生成随机码String capText = this.getIdentifyingCode(num);//redis 缓存存储,用于校验// redisClient.setex(getIdentifyingCodePreKey(uniqueId), 180, capText);map.put("image", this.img(width, height, num, capText));map.put("uniqueId", uniqueId);return map;}
/*** 获取cookie中的uniqueId** @param request* @return*/private String getUniqueIdFromCookie(HttpServletRequest request) {String uniqueId = "";Cookie[] cookies = request.getCookies();if (cookies != null) {for (Cookie cookie : cookies) {if (cookie.getName().endsWith("_UNIQUE_ID")) {uniqueId = cookie.getValue();break;}}}return uniqueId;}
/*** 生成图片** @param width* @param height* @param num* @param capText* @return*/public BufferedImage img(int width, int height, int num, String capText) {int x = width / (num + 1);int fontHeight = height - 2;int codeY = height - 4;// 定义图像bufferBufferedImage buffImg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);Graphics2D g = buffImg.createGraphics();// 创建一个随机数生成器类Random random = new Random();// 将图像填充为白色g.setColor(Color.WHITE);g.fillRect(0, 0, width, height);// 创建字体,字体的大小应该根据图片的高度来定Font font = new Font("Fixedsys", Font.PLAIN, fontHeight);// 设置字体g.setFont(font);// 画边框g.setColor(Color.WHITE);g.drawRect(0, 0, width - 1, height - 1);// 随机产生160条干扰线,使图像中的认证码不易被其他程序探测到g.setColor(Color.BLACK);for (int i = 0; i < 10; i++) {int xx = random.nextInt(width);int yy = random.nextInt(height);int x1 = random.nextInt(10);int y1 = random.nextInt(12);g.drawLine(xx, yy, xx + x1, yy + y1);}// randomCode用于保存随机产生的验证码,以便用户登录后进行验证String randomCode = capText;int red = 0, green = 0, blue = 0;// 随机产生codeCount数字的验证码for (int i = 0; i < randomCode.length(); i++) {// 产生随机的颜色分量来构造颜色值,这样输出的每位数字的颜色值都将不同red = random.nextInt(255);green = random.nextInt(255);blue = random.nextInt(255);// 用随机产生的颜色将验证码绘制到图像中g.setColor(new Color(red, green, blue));g.drawString(String.valueOf(randomCode.charAt(i)), (i + 1) * x, codeY);}return buffImg;}
/*** 生成随机码** @param num* @return*/private String getIdentifyingCode(int num) {Random random = new Random();String codeStr = "";// 生成验证码for (int i = 0; i < num; i++) {codeStr += String.valueOf(CODE_SEQUENCE[random.nextInt(36)]);}return codeStr;}
/*** 验证码长度*/@Value("5")private String codeLength;/*** 验证码字符*/private static final char[] CODE_SEQUENCE = {'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'};

controller代码:

@RequestMapping(value = "generate", method = RequestMethod.GET)public String generateIdentifyCode(HttpServletRequest request, HttpServletResponse response,@RequestParam(value = "width", required = false, defaultValue = "100") int width,@RequestParam(value = "height", required = false, defaultValue = "30") int height) {response.setDateHeader("Expires", 0);response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");response.addHeader("Cache-Control", "post-check=0, pre-check=0");response.setHeader("Pragma", "no-cache");//生成图片上的文字Map<String, Object> map = identifyingCodeService.generateIdentifyCode(request, width, height);String uniqueId = (String) map.get("uniqueId");Cookie cookie = new Cookie("_UNIQUE_ID", uniqueId);//60s过期cookie.setMaxAge(120);cookie.setPath("/");response.addCookie(cookie);ServletOutputStream out = null;try {out = response.getOutputStream();ImageIO.write((BufferedImage) map.get("image"), "jpg", out);// 强制将缓冲区所有的数据输出!out.flush();} catch (IOException e) {// ApiLogger.error("generate identify code is error, e " + e);} finally {try {if (null != out) {out.close();}} catch (IOException e) {// ApiLogger.error("generate identify code, close out is error, e " + e);}}return null;}

返回结果:
在这里插入图片描述
验证起来也方便,因为在创建验证码的时候已经在redis存储了value,直接请求对比验证即可。
需注意:图片生成大小调整还是得根据想要的验证码位数来调试长宽高


http://chatgpt.dhexx.cn/article/dkimXF4p.shtml

相关文章

C# 图片验证码简单例子

C# 图片验证码简单例子 一、简述 记--使用PictureBox绘制验证码。 例子&#xff1a;外链:https://wwm.lanzouq.com/b0cafckej 密码:cxxn 二、效果 三、工程结构 四、源文件 Form1.cs文件 using System; using System.Drawing; using System.Windows.Forms;namespace Verifi…

springboot图片验证码

前言: 大家好&#xff01;我是小小&#xff01;今天我们用五分钟来用springboot实现我们常用的图形验证码功能模块&#xff01; 用户登录几乎是一个线上系统必不可少且使用相对比较频繁的一个模块&#xff0c;为了防止恶意暴力尝试&#xff0c;防止洪水攻击、防止脚本自动提交…

JavaWeb总结之通过Servlet生成验证码图片

项目地址:https://github.com/zhangzeminzZ/ServletStudy 目录 1.BufferedImage类介绍2.在Form表单中使用验证码图片3.服务器端对form表单提交上来的验证码处理 1.BufferedImage类介绍 生成验证码图片主要用到了一个BufferedImage类 创建一个DrawImage Servlet&#xff0c;用…

网站安全检测之图片验证码

2019独角兽企业重金招聘Python工程师标准>>> 在对网站安全进行整体的安全检测的时候&#xff0c;用户登陆以及用户留言&#xff0c;评论&#xff0c;设置支付密码&#xff0c;以及一些网站功能方面都会用到图片验证码&#xff0c;针对于验证码我们SINE安全对其进行了…

实现图片验证码【详细代码】

实际开发过程中经常遇到要实现图片验证码来防止外部使用脚本刷接口&#xff0c;所以说图片验证码是很有必要的一个小功能。 html <!--- 注册页面整增加图形验证码功能,这里为了更贴近企业级业务&#xff0c;我们在注册页面整增加图形验证码功能--> <div class"u…

图片验证码实现的几种方式

一、Google Kaptcha 1、简介 kaptcha 是一个非常实用的验证码生成工具。有了它&#xff0c;你可以生成各种样式的验证码&#xff0c;因为它是可配置的。kaptcha工作的原理是调用 com.google.code.kaptcha.servlet.KaptchaServlet&#xff0c;生成一个图片。同时将生成的验证码…

ajax请求后台返回数据

功能介绍&#xff1a;最近学习在做一个新闻管理系统&#xff0c;其中有一个模块做的是一个排行榜功能&#xff0c;分为东部联盟和西部联盟&#xff0c;当我点击他的时候&#xff0c;排行的数据会发生变化。由于这一块怎么整个页面中的一小块&#xff0c;所以使用的是局部刷新页…

如何取消ajax请求

之前在面试的时候&#xff0c;被面试官问到了如何取消ajax请求&#xff0c;然鹅并不知道&#xff0c;被刷之后痛定思痛&#xff0c;总结了原生XHR、jquery、axios取消ajax请求的方法。 原生XHR 对于原生XHR对象来说&#xff0c;取消的ajax的关键是调用XHR对象的.abort()方法 …

HTML AJAX请求调用

html ajax请求 ------------------温故而知新,可以装逼矣-------------------- 大佬提出需求&#xff0c;访问html文件&#xff0c;动态响应文章内容 作为一个纯正&#xff08;半吊子&#xff09;的JAVA后端写太多前后端分离的项目&#xff0c;太久没接触前端知识。头都是炸的…

ajax请求五个步骤!

ajax请求五个步骤&#xff01; 今天 咱们讲一讲Ajax请求五个步骤&#xff01; 1.创建XMLHttpRequest异步对象 var xhr; if (window.XMLHttpRequest){// code for IE7, Firefox, Chrome, Opera, Safarixhrnew XMLHttpRequest();} else{// code for IE6, IE5xhrnew ActiveXObje…

jquery(五)Ajax请求

在jQuery中AJAX的写法有3种&#xff0c;$ajax&#xff0c;$post&#xff0c;$get这三种。其中$post和$get是简易写法&#xff0c;高层的实现&#xff0c;在调用他们的时候&#xff0c;会运行底层封装好的$ajax。 ajax写法 $.ajax({url:"http://www.microsoft.com",…

Ajax请求参数

Ajax请求参数 GET请求参数的传递创建服务器通过表单访问服务器 POST请求参数的传递application/x-www-form-urlencoded参数的接收与发送创建服务器通过表单访问服务器 JSON格式数据的发送与接收创建服务器通过表单访问服务器 GET请求参数的传递 设置open()方法中的第1个参数为…

Ajax请求以及发送Ajax请求的方式

1.在写C语言时候&#xff0c;写了好长时间&#xff0c;终于开始运行了&#xff0c;结果出现了这种情况&#xff0c;以前就没见过。 原来是自己的函数名写错了&#xff0c;main写成了amin.所以写代码一定要细心&#xff0c;不然会给你带来很失望的心情。 2.Ajax请求步骤 //1.创…

html的ajax请求

页面中ajax发起请求&#xff0c;controller接收数据并处理 这次ajax的测试以访问html的方式配置 配置yml文件&#xff1a; 然后在 src/main/webapp下创建一个html页面 创建controller&#xff1a; 运行项目就可以访问到index.html&#xff1a; 引入jquery&#xff1a; 修改…

Ajax请求详解

Ajax请求 一、什么是Ajax二、Ajax原理是什么三、Ajax的使用1.创建Ajax核心对象XMLHttpRequest(记得考虑兼容性)2.向服务器发送请求3.服务器响应处理&#xff08;区分同步跟异步两种情况&#xff09;①同步处理②异步处理③GET和POST请求数据区别 四、结束语五、jQuery的ajax函数…

Ajax原理一篇就够了

前言 AJAX即“Asynchronous Javascript And XML”,是指一种创建交互式网页应用的网页开发技术。AJAX 是一种用于创建快速动态网页的技术。它可以令开发者只向服务器获取数据(而不是图片,HTML文档等资源),互联网资源的传输变得前所未有的轻量级和纯粹,这激发了广大开发者的…

Ajax请求

ajax请求简介&#xff1a; ajax是利用前端的技术&#xff0c;向服务器发送一个异步请求 原有的请求在请求后需要刷新整张页面&#xff0c;但是用ajax请求后只需要刷新一部分页面即可&#xff1b; xhr基础属性&#xff1a; Jquery与ajax&#xff1a;使用$.ajax({}) Ajax的html…

Ajax请求的五个步骤

目录 Ajax请求的五个步骤 一、定义 1、什么是Ajax 2、同步与异步的区别 3、ajax的工作原理 二、实现AJAX的基本步骤 1、创建XMLHttpRequest对象 2、创建HTTP请求 3、设置响应HTTP请求状态变化的函数 4、设置获取服务器返回数据的语句 5、发送HTTP请求 6、局部更新 …

详解Ajax请求

目录 1.$.get()函数的语法 2.$.get()发起不带参数的请求 3.$.get()发起带参数的请求 4.$.post()函数的语法 5.$.post()向服务器提交数据 6.$.ajax()函数的语法 7.使用$.ajax()发起GET请求 ​8.使用$.ajax()发起POST请求 1.$.get()函数的语法 jQuery中$.get()函数的功能单…

linux下输入法,中英文自由切换,仍无法输入中文

1、安装中文输入法&#xff1a;yum install "Chinese Support" 2、中英文切换&#xff1a;Super空格 &#xff08;其中Super键在Ctrl和Alt之间&#xff09; 也可以直接点击右上角进行切换 3、设置输入源&#xff1a;如果直接选择汉语的话&#xff0c;即使中英文可以…