图片验证码

article/2025/9/20 20:59:42

通过下面这个方法可以得到随机验证码:


public String getIdentifyCode(){//得到验证码(数字+大小写字母)String str="";Random rand=new Random();for(int i=0;i<6;i++){switch(rand.nextInt(3)){case 0:int a=(int) (Math.random()*26+65);char b=(char) a;str+=b;break;case 1:int c=(int) (Math.random()*26+97);char e=(char)c;str+=e;break;case 2:int d=(int) (Math.random()*10+48);char f=(char)d;str+=f;break;}}return str;
}

下面开始介绍另一种:
在项目中的登录页面写图片验证码:

下面的这个VerifyCode类你可以将它封装成jar包,以后如果要写图片验证码的话,就可以直接使用了。

package cn.itcast.utils;import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics2D;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Random;import javax.imageio.ImageIO;public class VerifyCode {private int w = 70;private int h = 35;private Random r = new Random();private String[] fontNames  = {"宋体", "华文楷体", "黑体", "华文新魏", "华文隶书", "微软雅黑", "楷体_GB2312"};private String codes  = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";private Color bgColor  = new Color(240, 240, 240);private String text ;private Color randomColor () {//产生随机颜色int red = r.nextInt(256);int green = r.nextInt(256);int blue = r.nextInt(256);return new Color(red, green, blue);}private Font randomFont () {//产生随机字体int index = r.nextInt(fontNames.length);String fontName = fontNames[index];int style = r.nextInt(4);int size = r.nextInt(5) + 24; return new Font(fontName, style, size);}private void drawLine (BufferedImage image) {//在图片上画干扰线。(一般来说,验证码图片上都会有一、两条干扰线就是为了防止黑客写程序恶意进行验证)int num  = 5;Graphics2D g2 = (Graphics2D)image.getGraphics();//通过这个类画线for(int i = 0; i < num; i++) {int x1 = r.nextInt(w);int y1 = r.nextInt(h);int x2 = r.nextInt(w);int y2 = r.nextInt(h); g2.setStroke(new BasicStroke(1.5F)); g2.setColor(Color.BLUE); g2.drawLine(x1, y1, x2, y2);}}private char randomChar () {//产生随机字符int index = r.nextInt(codes.length());return codes.charAt(index);}private BufferedImage createImage () {//定义一个图像缓冲区来存放你所创建的图片BufferedImage image = new BufferedImage(w, h, BufferedImage.TYPE_INT_RGB); Graphics2D g2 = (Graphics2D)image.getGraphics(); g2.setColor(this.bgColor);g2.fillRect(0, 0, w, h);return image;}public BufferedImage getImage () {//得到图片BufferedImage image = createImage(); Graphics2D g2 = (Graphics2D)image.getGraphics();StringBuilder sb = new StringBuilder();// 向验证码图片中画4个字符for(int i = 0; i < 4; i++)  {String s = randomChar() + ""; sb.append(s); float x = i * 1.0F * w / 4; g2.setFont(randomFont()); g2.setColor(randomColor()); g2.drawString(s, x, h); }this.text = sb.toString(); drawLine(image); return image;		}public String getText () {//得到图片上的验证码文本return text;}public static void output (BufferedImage image, OutputStream out) throws IOException {ImageIO.write(image, "JPEG", out);//将图片以IO流的方式输出}
}

具体用法:
当要用的时候,就将上面的类封装成jar包导入你的项目。或者将上面代码写到你的项目中的utils包中。
然后在前端登录页面login.jsp这样写:

<form action="<c:url value='/LoginServlet'/>"   method="post"><input type="hidden" name="method"  value="login"/><table border="1" style="float:right; margin-top:260px;margin-right:800px;border-radius:10px;height:270px" ><tr><th>用户登录</th></tr><tr><td><I>用户名:</I>   <INPUT type="text" name="username"/></td></tr><tr><td><I>密  码:</I>   <INPUT  type="password" name="password"/></td></tr><tr><td><I>验证码:</I>  <INPUT type="text" name="verifycode" /> <img src="<c:url value='/VerifycodeServlet?Vname=logincode' />"  border='2' id='oImg' /><a href="javascript:;" onclick=change()><font color=gold size='0'>看不清,换一张</font></a><br/> </td></tr><tr><td>		<INPUT type="submit" value="登录" id="button1"></td><td><label ><font color=red size='2'>${msg }</font></label>//这里是用来显示报错信息的</td></tr></table></form><script>function change(){//点击“看不清,换一张”时触发这个事件var img=document.getElementById("oImg"); img.src="<c:url value='/VerifycodeServlet?name=logincode&' />"+(new Date()).getTime();}</script>

上面的<c:url value=’/VerifycodeServlet?name=logincode&’ />仅仅是因为使用了jstl中的c标签库中的url标签(好处是:即使你项目名改变了。它也还是可以即时获得你改动后的项目名)。不必奇怪,如果你不想用。也可以直接写你要访问的路径。

然后,VerifycodeServlet类中这样写:如下

public class VerifycodeServlet extends HttpServlet {public void doGet(HttpServletRequest req, HttpServletResponse res)throws ServletException, IOException {req.setCharacterEncoding("utf-8");res.setContentType("text/html;charset=utf-8");System.out.println("=========================");String namevalue=req.getParameter("Vname");//获取参数name的参数值即:logincodeֵVerifyCode vc=new VerifyCode();//创建自定义的验证码类的对象BufferedImage image=vc.getImage();//设置图片缓存器req.getSession().setAttribute(namevalue, vc.getText());//把图片上的验证码保存到namevalue这个域属性中(即:保存到logincode中),在LoginServlet类中对用户输入的进行验证码进行校对的时候  方便取出来System.out.println(vc.getText());//在控制台上显示验证码,方便你对照VerifyCode.output(image,res.getOutputStream());}
}

然后,在后台的LoginServlet中这样写:(校验用户输入的验证码是否正确)
在这里插入图片描述

最终的效果是和这差不多:
在这里插入图片描述


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

相关文章

图片验证码破解

2.8图片验证码破解 在测试web平台时&#xff0c;难以避免的就是登录&#xff0c;登录的时候就会需要输入验证码&#xff01;有的是图型验证码有的是滑动验证码&#xff0c;那么在自动化中如何破解验证码&#xff1f;这里只介绍简单的图片验证码。 一般来说破解这种图形验证码…

Java实现图片验证码功能

文章目录 一、背景二、实现步骤1、maven中加入依赖2、CaptchaController.java3、生成验证码配置4、CaptchaService.java接口5、CaptchaServiceImpl.java实现类6、增加验证码校验涉及文件 一、背景 在实现登录功能时&#xff0c;为了防止特定的程序暴力破解&#xff0c;一般为了…

python 图片验证码

1.图片验证码第一步 # 导入绘图库 from PIL import ImageDraw, Image, ImageFont 2.生成图片验证类 # 图片验证类 class ImgCode(BaseHandler):# 定义随机颜色实例方法def get_random_color(self):R random.randrange(255)G random.randrange(255)B random.randrange(255)…

java 生成图片验证码

https://vimsky.com/zh-tw/examples/detail/java-class-javax.servlet.ServletOutputStream.html 开发过程中&#xff0c;需要服务端返回验证码图片给前台&#xff0c;想想该如何实现呢&#xff1f; 1、字节流的输入输出 2、生成一个验证码&#xff0c;自定义字母数字混合实现…

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文档等资源),互联网资源的传输变得前所未有的轻量级和纯粹,这激发了广大开发者的…