博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实现网站验证码切换功能
阅读量:4689 次
发布时间:2019-06-09

本文共 2234 字,大约阅读时间需要 7 分钟。

 实现网站验证码切换功能

一、样例

 样例1、

样例2、

 

 

 

 

 二、实现原理

 

 

三、实现代码

com.fry.servlet.VerifyCodeServlet

1 package com.fry.servlet; 2  3 import javax.imageio.ImageIO; 4 import javax.servlet.ServletException; 5 import javax.servlet.annotation.WebServlet; 6 import javax.servlet.http.HttpServlet; 7 import javax.servlet.http.HttpServletRequest; 8 import javax.servlet.http.HttpServletResponse; 9 import java.awt.*;10 import java.awt.image.BufferedImage;11 import java.io.IOException;12 import java.util.Random;13 14 /**15  * Created by fry on 2017/5/31.16  */17 @WebServlet(name = "VerifyCodeServlet", urlPatterns = "/code")18 public class VerifyCodeServlet extends HttpServlet {19     protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {20 21     }22 23     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {24         int width = 100;25         int height = 30;26 27         String data = "abcdefghijklmnopqrst01234567890";28 29         Random random = new Random();30         //1、用BufferedImage生成一张图片,最后一个参数是图片类型31         BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);32 33         //3、调用image的画图对象34         Graphics graphics = image.getGraphics();35         graphics.setColor(Color.gray);36         //左上角和右下角37         graphics.fillRect(0, 0, width, height);38 39 40         graphics.setColor(Color.black);41         for (int i = 0; i < 4; i++) {42             //4、随机生成字符串,取到随机的位置,就取到了随机的字符串43             int position = random.nextInt(data.length());44             String randomStr = data.substring(position, position + 1);//分割字符串45             graphics.drawString(randomStr, width / 5 * (i + 1), 15);//画字符串46 47         }48 49         //2、ImageIO的write()方法可以将图片转化为OutputStream类型50         /**51          * 第二个参数是要格式化的类型52          * 最后一个参数是将格式化的图片写到response的输出流中53          */54         ImageIO.write(image, "jpg", response.getOutputStream());55 56 57     }58 }

 

verifyCode.html

 要让按钮一直能点

1  2  3  4     
5 Title 6 7 8 9 10
11

切换验证码

12
13
20
21
22
23 24
25

 

 

转载于:https://www.cnblogs.com/Renyi-Fan/p/7761824.html

你可能感兴趣的文章
jquery 取id模糊查询
查看>>
解决在vue中,自用mask模态框出来后,下层的元素依旧可以滑动的问题
查看>>
修改node节点名称
查看>>
PAT(B) 1014 福尔摩斯的约会(Java)
查看>>
PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
查看>>
项目开发总结报告(GB8567——88)
查看>>
SSH加固
查看>>
端口扫描base
查看>>
iOS IM开发的一些开源、框架和教程等资料
查看>>
FansUnion:共同写博客计划终究还是“流产”了
查看>>
python 二维字典
查看>>
pip 警告!The default format will switch to columns in the future
查看>>
Arrays类学习笔记
查看>>
实验吧之【天下武功唯快不破】
查看>>
2019-3-25多线程的同步与互斥(互斥锁、条件变量、读写锁、自旋锁、信号量)...
查看>>
win7-64 mysql的安装
查看>>
dcm4chee 修改默认(0002,0013) ImplementationVersionName
查看>>
maven3在eclipse3.4.2中创建java web项目
查看>>
发布时间 sql语句
查看>>
黑马程序员 ExecuteReader执行查询
查看>>