java实现图形验证码

项目中可能会用到图形验证码的功能,源码分享给大家。以下是实际效果图:
在这里插入图片描述

一、后端JAVA代码

1.生成图形验证码工具类

public class imgVerifyCode {private int weight = 100;           //验证码图片的长和宽private int height = 40;private String text;                //用来保存验证码的文本内容private Random r = new Random();    //获取随机数对象//private String[] fontNames = {"宋体", "华文楷体", "黑体", "微软雅黑", "楷体_GB2312"};   //字体数组//字体数组private String[] fontNames = {"Georgia"};//验证码数组private String codes = "23456789abcdefghjkmnopqrstuvwxyzABCDEFGHJKMNPQRSTUVWXYZ";/*** 获取随机的颜色** @return*/private Color randomColor() {int r = this.r.nextInt(225);  //这里为什么是225,因为当r,g,b都为255时,即为白色,为了好辨认,需要颜色深一点。int g = this.r.nextInt(225);int b = this.r.nextInt(225);return new Color(r, g, b);            //返回一个随机颜色}/*** 获取随机字体** @return*/private Font randomFont() {int index = r.nextInt(fontNames.length);  //获取随机的字体String fontName = fontNames[index];int style = r.nextInt(4);         //随机获取字体的样式,0是无样式,1是加粗,2是斜体,3是加粗加斜体int size = r.nextInt(10) + 24;    //随机获取字体的大小return new Font(fontName, style, size);   //返回一个随机的字体}/*** 获取随机字符** @return*/private char randomChar() {int index = r.nextInt(codes.length());return codes.charAt(index);}/*** 画干扰线,验证码干扰线用来防止计算机解析图片** @param image*/private void drawLine(BufferedImage image) {int num = r.nextInt(10); //定义干扰线的数量Graphics2D g = (Graphics2D) image.getGraphics();for (int i = 0; i < num; i++) {int x1 = r.nextInt(weight);int y1 = r.nextInt(height);int x2 = r.nextInt(weight);int y2 = r.nextInt(height);g.setColor(randomColor());g.drawLine(x1, y1, x2, y2);}}/*** 创建图片的方法** @return*/private BufferedImage createImage() {//创建图片缓冲区BufferedImage image = new BufferedImage(weight, height, BufferedImage.TYPE_INT_RGB);//获取画笔Graphics2D g = (Graphics2D) image.getGraphics();//设置背景色随机
//        g.setColor(new Color(255, 255, r.nextInt(245) + 10));g.setColor(Color.white);g.fillRect(0, 0, weight, height);//返回一个图片return image;}/*** 获取验证码图片的方法** @return*/public BufferedImage getImage() {BufferedImage image = createImage();Graphics2D g = (Graphics2D) image.getGraphics(); //获取画笔StringBuilder sb = new StringBuilder();for (int i = 0; i < 4; i++)             //画四个字符即可{String s = randomChar() + "";      //随机生成字符,因为只有画字符串的方法,没有画字符的方法,所以需要将字符变成字符串再画sb.append(s);                      //添加到StringBuilder里面float x = i * 1.0F * weight / 4;   //定义字符的x坐标g.setFont(randomFont());           //设置字体,随机g.setColor(randomColor());         //设置颜色,随机g.drawString(s, x, height - 5);}this.text = sb.toString();drawLine(image);return image;}/*** 获取验证码文本的方法** @return*/public String getText() {return text;}public static void output(BufferedImage image, OutputStream out) throws IOException                  //将验证码图片写出的方法{ImageIO.write(image, "JPEG", out);}
}

由于项目需求,图形验证码的背景色我改为白色了,可根据自身情况选择图片背景色

        //设置背景色随机
//        g.setColor(new Color(255, 255, r.nextInt(245) + 10));g.setColor(Color.white);

2.生成验证码接口

	@RequestMapping("/getVerifiCode.action")@ResponseBodypublic String getVerifiCode(Map<String, Object> requestMap, HttpSession session, HttpServletRequest request, HttpServletResponse response) throws IOException {ImageVerificationCode ivc = new ImageVerificationCode();     //使用验证码类,生成验证码类对象BufferedImage image = ivc.getImage();  //获取验证码request.getSession().setAttribute("text", ivc.getText()); //将验证码的文本存在session中ivc.output(image, response.getOutputStream());//将验证码图片响应给客户端request.setCharacterEncoding("utf-8");String session_vcode=(String) request.getSession().getAttribute("text");    //从session中获取真正的验证码return session_vcode;}

3.校验验证码接口

	@RequestMapping(value = "/checkVerify", method = RequestMethod.POST, headers = "Accept=application/json")@ResponseBodypublic boolean checkVerify(@RequestParam String verifyInput, HttpSession session) {try {//从session中获取随机数String inputStr = verifyInput;String random = (String) session.getAttribute("text");if (random == null || "".equals(random) || !random.equalsIgnoreCase(inputStr)) {return false;} else {return true;}} catch (Exception e) {log.error("验证码校验失败", e);return false;}}

4.拦截器

不要忘记把拦截器放行这两个接口

二、HTML

<div class="form-group"><input type="text" id="verify_input" name="title" class="form-control"  placeholder="验证码" autocomplete="off" /><div id="verify_image" style="margin: -43px 0px 3px 200px;"><img id="imgVerify" style="color: white; cursor:pointer;width: 100px;height: 38px;margin: -38px -32px -22px 0;border-radius: 4px;" title="刷新验证码" onclick="getVerify(this);"></div>
</div>

三、JS

function getVerify() {$("#verify_input").val("");$("#imgVerify").attr("src", './getVerifiCode.action?' + Math.random());//jquery方式
}function aVerify() {let value = $("#verify_input").val();if (value == '') {alert('[[#{login.hint10}]]');return 0;}$.ajax({async: false,type: 'post',url: './checkVerify',dataType: "json",data: {verifyInput: value},success: function (result) {if (result) {.....//验证用户名密码逻辑} else {alert("验证码输入错误,请重新输入!");getVerify();}}});
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/253887.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

PHP生成图形验证码

PHP生成图形验证码 效果&#xff1a;随机生成6位验证码&#xff0c;100个干扰的黑点&#xff0c;一条干扰线 代码&#xff1a;image.php&#xff08;生成验证码&#xff09;和check.php&#xff08;验证验证码是否输入正确&#xff09; 效果图详见代码下面的截图 image.php &l…

图形验证码验证

图形验证码一般是防止恶意&#xff0c;人眼看起来都费劲&#xff0c;何况是机器。不少网站为了防止用户利用机器人自动注册、登录、灌水&#xff0c;都采用了验证码技术。所谓验证码&#xff0c;就是将一串随机产生的数字或符号&#xff0c;生成一幅图片&#xff0c; 图片里加上…

gin集成图形验证码

简介 github 文档 生成图形验证码 package mainimport ("github.com/gin-gonic/gin""github.com/mojocn/base64Captcha""net/http" )var store base64Captcha.DefaultMemStorefunc main() {r : gin.Default()group : r.Group("/captcha…

SpringBoot生成图形验证码

需求&#xff1a;验证码一码一用&#xff0c;验证之后&#xff0c;不管是成功还是失败&#xff0c;都需要重新获取或者刷新二维码。 大致思路&#xff1a;后端生成验证码后还需要生成一个UUID与之对应&#xff0c;存储到缓存&#xff08;记得添加过期时间&#xff09;&#xf…

自己实现图形验证码

如果不想重复造轮子&#xff0c;参考上一篇文章&#xff1a;SpringBoot生成图形验证码_Muscleheng的博客-CSDN博客 这里不需要依赖开源组件包&#xff0c;完全自己实现图形验证码功能 两步完成&#xff1a; 第一步&#xff1a;编写图形验证码工具 package com.zhh.demo.com…

图形验证码的使用

在用户登录的时候&#xff0c;除了要输入用户名和密码&#xff0c;有时候还需要输入验证码进行验证&#xff0c;如下&#xff1a; 现在一般用短信验证码比较多&#xff0c;但是图形验证码也有使用。记录一下图形验证码的使用过程。 1、验证码生成器 先定义一个验证码的生成器…

vue图形验证码

Vue图形验证码 组件 可以自行封装一下&#xff0c;放在components目录下。 <template><span class"s-canvas" click"changeCode"><canvas id"s-canvas" :width"contentWidth" :height"contentHeight">…

图形验证码安全

目录 图形验证码 图形验证码的作用和原理 图形验证码的分类 图形验证码的验证过程 图形验证码的安全问题 静态图形验证码的破解 利用Python脚本破解静态图形验证码 图形验证码 我们经常在登录app或者网页的时候&#xff0c;都会需要我们输入图形验证码上的内容&#xf…

图形验证码

一、图形验证码是什么&#xff1f; 图形验证码是一些没有规则的图文的组合&#xff0c;参考下图 二、图形验证码有什么用&#xff1f; 防止恶意攻击者采用恶意工具批量注册账号或是大量频繁调用某些请求&#xff0c;给服务器造成压力&#xff0c;占用大量的系统资源。 三、图形…

C语言——数据在内存中的存储(上)

数据在内存中的存储 1. 数据类型的介绍 之前已经介绍过C语言中的基本数据类型了&#xff0c;主要有&#xff1a; char //字符数据类型short //短整型int //整形long //长整型long long //更长的整形float //单精度浮点数double //双精度浮点数 注意&#xff1a;C语言中是是没…

php图形 验证码代码,PHP制作图形验证码代码分享,php图形验证码代码_PHP教程

PHP制作图形验证码代码分享,php图形验证码代码 效果: myvcode.class.php:封装创建验证码的类 /* * file:myvcode.class.php * 验证码类,类名Vcode */ class Vcode {private $width; /*验证码宽度*/ private $height; /*验证码高度*/ private $codeNum; /*验证码字符个数*/ p…

Android图形验证码

1. 前言 图形验证码可以让服务器以图片的形式传给客户端&#xff0c;也可以让客户端自己实现。那客户端要怎么做呢&#xff1f;其实很简单&#xff0c;可以使用Android的Canvas、Paint和Random来实现。用Random来随机生成数字、字母、颜色、画笔原点等等&#xff0c;设置Paint…

java生成图形验证码

随时随地阅读更多技术实战干货&#xff0c;获取项目源码、学习资料&#xff0c;请关注源代码社区公众号(ydmsq666) 首先&#xff0c;需要生成验证码字符串&#xff0c;方式很多&#xff0c;下面提供一种&#xff0c;根据指定源的方式来生成验证码 /*** 使用系统默认字符源生成验…

图形验证码最佳攻略2

下面是注册 如果是手机用户注册,需要发送短信验证码 说明: 发送图形验证码是为了拦截发送短信的.但是不拦截"注册帐号" 但是,用户体验很别扭,因为图形验证码很显然是错误的,但是却可以注册成功. 如果点击注册帐号 ,也要校验图形验证码,那就让用户输入两次图形验证码,…

小程序图形验证码输入校验例子

前言 本教程是基于 “apifm-wxapi” 模块&#xff0c;教你快速实现小程序开发&#xff0c;所以你可能需要先了解以下知识点&#xff1a; 《创建 HelloWorld 项目》《使用 “apifm-wxapi” 快速开发小程序》《免费注册开通后台&#xff0c;获得专属域名》 功能说明 图形验证码的…

Part1:使用 TensorFlow 和 Keras 的 NeRF计算机图形学和深度学习——计算机图形学世界中相机的工作原理

Part1&#xff1a;使用 TensorFlow 和 Keras 的 NeRF计算机图形学和深度学习 1. 效果图2. 原理2.0 前向成像模型2.1 世界坐标系2.2 相机坐标系2.3 坐标变换2.4 投影转换2.5 数据 3. 源码参考 是否有一种方法可以仅从一个场景多张不同视角的照片中捕获整个3D场景&#xff1f; 有…

IDEA+Mysql+Sqlserver安装步骤_kaic

下载Intellij 开发工具&#xff0c;如果有请检查软件是否过期&#xff0c;如果过期卸载电脑上的Intellij软件。卸载步骤&#xff1a; 打开控制面板&#xff0c;选择卸载程序找到Intellij右键卸载 如果没有请保存文档中的Intellij.zip压缩包,进行安装&#xff0c;安装步骤 双…

电脑重置网络

1、键盘WinR键&#xff0c;弹出窗口 2、然后在里面输入cmd输入CMD 3、出现的命令提示框内输入“netsh winsock reset"按”Enter“键 4、重启电脑后生效。

重置电脑

步骤1&#xff1a; 以Win10系统为例 直接在搜索框输入:reset 或者直接选择「设置」-「更新和安全」-「恢复」 步骤2&#xff1a; 步骤3&#xff1a; 根据个人情况选择【保留我的文件】或者【删除所有内容】

如何让Win10 重置此电脑功能无法使用

环境&#xff1a; Win10 专业版 问题描述&#xff1a; 通过设置-更新和安全-恢复-重置此电脑&#xff0c;如何让Win10 重置此电脑功能无法使用 解决方案&#xff1a; 1.PE下删除Win Re 恢复分区&#xff0c;然后重置就无法使用