javaweb-简单的验证码和算术验证码
我们登陆网站时,每次都会填写一些验证码,这些验证码的作用:防止被恶意攻击,验证码上面的字母数字一般都是随机生成的,因此我们首先要写一个方法生成一个随机的字符串,这里就需要java里面的随机函数Random,一般情况下我们将需要的字母数字放到一个静态的字符串中,让在随机生成一个数字下标,然后得到一个字符,验证码需要几个字符我们就生成几个字符。
(2)市面上的验证码一般都是以图片展示出来,因此我们需要一个图片的数据流,生成一个矩形的.jpg格式的图片。具体的代码展示:
- package com.imooc.code;
- import java.awt.Color;
- import java.awt.Font;
- import java.awt.Graphics2D;
- import java.awt.font.FontRenderContext;
- import java.awt.geom.Rectangle2D;
- import java.awt.image.BufferedImage;
- import java.util.Random;
- import javax.imageio.ImageIO;
- import javax.servlet.http.HttpServletResponse;
- public class CapchCode {
- public static String stringcode ="ABCDEFGHIJKLMNOPQISTUVWXYZ1234567890";
- public static Random random = new Random();
- public static String drawImage(HttpServletResponse response){
- //1,得到随机生成的字符串
- String code = drawString().toString();
- //定义图片的宽度和高度
- int height =25;
- int width = 70;
- //2。创建一个图片流
- BufferedImage CodeImage = new BufferedImage(width,height,BufferedImage.TYPE_3BYTE_BGR);
- //3:获取到 Graphics2D 绘制对象,开始绘制验证码
- Graphics2D graphics2D = CodeImage.createGraphics();
- //设置字体和颜色
- Font font = new Font("微软雅黑", Font.PLAIN, 20);
- Color color = new Color(0,0,0);
- graphics2D.setColor(color);
- graphics2D.setFont(font);
- //设置背景
- graphics2D.setBackground(new Color(226,226,240));
- //开始绘制对象的位置与长宽
- graphics2D.clearRect(0,0,width,height);
- //绘制形状,获取矩形对象
- //绘制形状,获取矩形对象
- FontRenderContext context = graphics2D.getFontRenderContext();
- Rectangle2D bounds = font.getStringBounds(code,context);
- double x = (width - bounds.getWidth())/2;
- double y = (height - bounds.getHeight())/2;
- double ascent = bounds.getY();
- double baseY = y - ascent;
- graphics2D.drawString(code,(int)x,(int)baseY);
- //结束绘制
- graphics2D.dispose();
- try {
- ImageIO.write(CodeImage,"jpg",response.getOutputStream());
- //刷新响应流
- response.flushBuffer();
- }catch(Exception ex){
- ex.printStackTrace();
- }
- return code;
- }
- //产生一个Stringbuffer的字符串
- public static StringBuffer drawString(){
- StringBuffer buffer = new StringBuffer();
- for(int i=0;i<4;i++)
- buffer.append(stringchar());
- return buffer;
- }
- //随机产生一个字母
- public static char stringchar(){
- return stringcode.charAt(random.nextInt(stringcode.length()));
- }
- }
(3)我们有时候登陆的时候,会遇到验证码看不清,或者不确定的情况下,需要重新生成一个有效的验证码。但是现在一般的浏览器都有记忆存储的功能,我们第一次生成一个验证码,如果不进行清除,那么就会一直展示第一个验证码,因此需要一个jsp来清理缓存。
- <%@ page language="java" contentType="text/html; charset=UTF-8"
- pageEncoding="UTF-8"%>
- <%@page import="com.imooc.code.CapchCode" %>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <%
- //1:清空浏览器缓存,目的是为了清空浏览器的缓存,因为浏览器
- //会对网站的资源文件和图像进行记忆存储,如果被浏览器加载过的图片就记忆起来,记忆以后
- //文件就不会和服务器在交互,如果我们验证不清空的话可能会造成一个问题就是:验证刷新以后没有效果。
- response.setHeader("pragma","no-cache");
- response.setHeader("cache-control","no-cache");
- response.setHeader("expires","0");
- //2:调用编写的生成验证码的工具
- String code = CapchCode.drawImage(response);
- session.setAttribute("code",code);
- //3:如何解决getOutputStream异常问题
- out.clear();
- out = pageContext.pushBody();
- %>
(4) 最后将生成的验证码展示出来:
- <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
- <!DOCTYPE HTML>
- <html>
- <head>
- <title>java验证码</title>
- <meta http-equiv=www.longboshyl.cn "pragma" content="no-cache">
- <meta http-equiv=www.thd540.com "cache-control" content="no-cache">
- <meta http-equiv=www.dfgjpt.com/ "expires" content="0">
- </head>
- <body>
- <img src="code.jsp" alt=www.zhongdayule.cn/ "" id="code">
- <a href="javascript:void(0);" onclick="changeCode()">看不清?点我</a>
- <script>
- function changeCode(www.yongshi123.cn ) {
- document.getElementById("code").src = "code.jsp?d="+new Date().getTime();
- }
- </script>
- </body>
- </html>
( 5)结果展示:
(6)算术验证码:算术验证码较之上面多了一个干扰线的设置,其余的没有特别的设置。
主要代码展示:
- package com.www.jypt178.cn imooc.code;
- import java.awt.Color;
- import java.awt.www.fengshen157.com Font;
- import java.awt.Graphics2D;
- import java.awt.image.BufferedImage;
- import java.util.Random;
- import javax.imageio.ImageIO;
- import javax.servlet.http.HttpServletResponse;
- public class CapchCode {
- /*
- * 算术验证码的实现
- */
- public static String drawImageVerificate(HttpServletResponse response){
- //设置长宽
- int width=100,height=30;
- //在内存中创建图片
- BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
- // 创建图片的上下文
- Graphics2D g = image.createGraphics();
- // 创建随机对象,此随机对象主要运用于算术表达式的数字
- Random random = new Random();
- //随机设置背景颜色
- g.setColor(getRandomColor(240,250));
- g.setFont(new Font("微软雅黑", Font.PLAIN, 22));
- //开始绘制
- g.fillRect(0, 0, width, height);
- g.setColor(getRandomColor(180,230));
- //主要的部分,设置干扰线,绘制线条到干扰线中
- for(int i=0;i<10;i++){
- int sx = random.nextInt(width);
- int sy = random.nextInt(height);
- int dx = random.nextInt(60);
- int dy = random.nextInt(60);
- g.drawLine(sx,sy, dx, dy);
- }
- // 对算术表达式的拼接
- int num1 = (int)(Math.random()*10+1);
- int num2 = (int)(Math.random()*10+1);
- int result=0;
- int fuhao = random.nextInt(3);
- String fuhaostr = "";
- switch (fuhao) {
- case 1:
- result = num1+num2;
- fuhaostr = num1+" + "+num2+" = ?";
- break;
- case 2:
- result = num1 - num2 ;
- fuhaostr = num1+" - "+num2+" = ?";
- case 3:
- result = num1 * num2;
- fuhaostr = num1 +" * "+num2+" = ?";
- break;
- }
- // 设置随机颜色
- g.setColor(new Color(20+random.nextInt(110), 20+random.nextInt(110),20+random.nextInt(110)));
- // 绘制表达式
- g.drawString(fuhaostr, 5, 25);
- //结束绘制
- g.dispose();
- try{
- //输出图片到页面
- ImageIO.write(image, "JPEG", response.getOutputStream());
- }catch(Exception e){
- e.printStackTrace();
- return null;
- }
- return null;
- }
- public static Color getRandomColor(int fa,int bc){
- if(fa>255)fa=255;
- if(bc>255)bc=255;
- Random random = new Random();
- int r = fa +random.nextInt(bc-fa);
- int g = fa +random.nextInt(bc-fa);
- int b = fa +random.nextInt(bc-fa);
- return new Color(r,g,b);
- }
--------------------- 本文来自 AYZXX 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/AYZXX/article/details/82907262?utm_source=copy
javaweb-简单的验证码和算术验证码的更多相关文章
- JAVA整合kaptcha生成验证码 (字母验证码和算术验证码)
引入maven <!--图片验证码--> <dependency> <groupId>com.github.penggle</groupId> < ...
- windows下简单验证码识别——完美验证码识别系统
此文已由作者徐迪授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 讲到验证码识别,大家第一个可能想到tesseract.诚然,对于OCR而言,tesseract确实很强大,自带 ...
- C#简单的四位纯数字验证码
验证码练手,整型.四位验证码 大体意思就是:四位纯数字验证,只要验证不成功就无限验证 刚开始在纠结怎么让整个过程循环起来,什么循环放到最外层,其实就是一个循环,看来自己的循环练习的还是不够多,不够灵活 ...
- 简单的Session案例 —— 一次性验证码
一次性验证码的主要目的就是为了限制人们利用工具软件来暴力猜测密码,其原理与利用Session防止表单重复提交的原理基本一样,只是将表单标识号变成了验证码的形式,并且要求用户将提示的验证码手工填写进一个 ...
- 以java实现的一个简单登录界面(带验证码)
本文参考于:https://blog.csdn.net/wyf2017/article/details/78831744 https://blog.csdn.net/MengKun822/articl ...
- 如何使用深度学习破解验证码 keras 连续验证码
在实现网络爬虫的过程中,验证码的出现总是会阻碍爬虫的工作.本期介绍一种利用深度神经网络来实现的端到端的验证码识别方法.通过本方法,可以在不切割图片.不做模板匹配的情况下实现精度超过90%的识别结果. ...
- PHP算式验证码和汉字验证码的实现方法
在PHP网站开发中,验证码可以有效地保护我们的表单不被恶意提交,但是如果不使用算式验证码或者汉字验证码,仅仅使用简单的字母或者数字验证码,这样的验证码方案真的安全吗? 大家知道简单数字或者字母验证码很 ...
- 从12306网站新验证码看Web验证码设计与破解
2015年3月16日,铁路官方购票网站12306又出新招,在登录界面推出了全新的验证方式,用户在填写好登录名和密码之后,还要准确的选取图片验证码才能登陆成功.据悉,12306验证码改版后,目前所有抢票 ...
- tornado web高级开发项目之抽屉官网的页面登陆验证、form验证、点赞、评论、文章分页处理、发送邮箱验证码、登陆验证码、注册、发布文章、上传图片
本博文将一步步带领你实现抽屉官网的各种功能:包括登陆.注册.发送邮箱验证码.登陆验证码.页面登陆验证.发布文章.上传图片.form验证.点赞.评论.文章分页处理以及基于tornado的后端和ajax的 ...
随机推荐
- 唱吧APP产品体验报告
- IOS CoreData 多表查询(下)
http://blog.csdn.net/fengsh998/article/details/8123392 在iOS CoreData中,多表查询上相对来说,没有SQL直观,但COREDATA的功能 ...
- Ubuntu下手动安装NextCloud
安装环境:阿里云VPS Ubuntu 16.04 一. 安装Apache2 sudo apt-get install apache2 安装完成后,浏览器访问http://your ip/,出现It ...
- Spring归纳
Spring总结 bean标签的scope属性 scope="singleton",单例模式,默认值 scope="prototype",多例模式 注解元素 @ ...
- webpack配置指南
Webpack已经出来很久了,相关的文章也有很多,然而比较完整的例子却不是很多,让很多新手不知如何下脚,下脚了又遍地坑 说实话,官方文档是蛮乱的,而且有些还是错的错的..很多配置问题只有爬过坑才知道 ...
- CornerStone使用跳坑总结
Cornerstone是专门为Mac用户设计的Subversion(SVN)的控制,使版本控制更加透明.cornerstone根Xcode相比,能够更好的忽略文件,所以除了项目经理第一次初始化项目的时 ...
- on() 和 click() 的区别
on() 和 click() 的区别: 二者在绑定静态控件时没有区别,但是如果面对动态产生的控件,只有 on() 能成功的绑定到动态控件中. 以下实例中原先的 HTML 元素点击其身后的 Delete ...
- Android读书笔记三
通过一章的学习体会到Git的重要性,因为想要获取开源的源代码,必须要使用Git,而且Linux内核完全是由Git管理的.Git是对源代码进行管理,在使用之前需要先安装,命令是 (1)apt-get i ...
- 【数学 技巧】divisor
没考虑重复lcm处理被卡TLE没A真是可惜 题目大意 $n$为$k-可表达的$当且仅当数$n$能被表示成$n$的$k$个因子之和,其中$k$个因子允许相等. 求$[A,B]$之间$k-可表达$的数的个 ...
- 【启发式搜索】Codechef March Cook-Off 2018. Maximum Tree Path
有点像计蒜之道里的 京东的物流路径 题目描述 给定一棵 N 个节点的树,每个节点有一个正整数权值.记节点 i 的权值为 Ai.考虑节点 u 和 v 之间的一条简单路径,记 dist(u, v) 为其长 ...