day84 json中实现简单验证码

2024-04-29 18:12

本文主要是介绍day84 json中实现简单验证码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目中的问题:
        1 修改JS或CSS后,页面不能及时更新?
                把浏览器-->"开发者工具"-->"网络"-->选中"禁用缓存"
        2 如何把HTML页面转为JSP页面
 将jsp页面中的<%@ page contentType="text/html;charset=UTF-8" language="java" %>指令复制到html文件头

3 如何实现简单验证码操作:  

          生成验证码的RandomCodeController类

package com.xja.controller; /*** @author 赵淑娜* Date  2024/4/26 10:15*/import javax.imageio.ImageIO;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;@WebServlet(name = "randomCode.do", value = "/RandomCodeController")
public class RandomCodeController extends HttpServlet {private static final String CONTENT_TYPE = "image/jpeg";//Initialize global variablespublic void init() throws ServletException {}//产生随机颜色函数getRandColorColor getRandColor(int fc, int bc) {Random r = new Random();if (fc > 255) fc = 255;if (bc > 255) bc = 255;int red = fc + r.nextInt(bc - fc); //红int green = fc + r.nextInt(bc - fc); //绿int blue = fc + r.nextInt(bc - fc); //蓝return new Color(red, green, blue);}//Process the HTTP Get requestpublic void doGet(HttpServletRequest request, HttpServletResponse response) throwsServletException, IOException {response.setContentType(CONTENT_TYPE);HttpSession session = request.getSession();//设置页面不缓存response.setHeader("Pragma", "No-cache");response.setHeader("Cache-Control", "no-cache");response.setDateHeader("Expires", 0);//创建随机类Random r = new Random();// 在内存中创建图像,宽度为width,高度为heightint width = 60, height = 20;BufferedImage pic = new BufferedImage(width, height,BufferedImage.TYPE_INT_RGB);// 获取图形上下文环境Graphics gc = pic.getGraphics();// 设定背景色并进行填充gc.setColor(getRandColor(200, 250));gc.fillRect(0, 0, width, height);//设定图形上下文环境字体gc.setFont(new Font("Times New Roman", Font.PLAIN, 20));// 随机产生200条干扰直线,使图像中的认证码不易被其他分析程序探测到for (int i = 0; i < 200; i++) {int x1 = r.nextInt(width);int y1 = r.nextInt(height);int x2 = r.nextInt(15);int y2 = r.nextInt(15);gc.setColor(getRandColor(160, 200));gc.drawLine(x1, y1, x1 + x2, y1 + y2);}//随机产生100个干扰点,使图像中的验证码不易被其他分析程序探测到for (int i = 0; i < 100; i++) {int x = r.nextInt(width);int y = r.nextInt(height);gc.setColor(getRandColor(120, 240));gc.drawOval(x, y, 0, 0);}// 随机产生4位数字的验证码String RS = "";String rn = "";RS = r.nextInt(9000) + 1000 + "";/*for(int i=0;i<4;i++){//产生10以内随机数字rnrn=String.valueOf(r.nextInt(10));RS+=rn;//将认证码用drawString函数显示到图像里gc.setColor(new Color(20+r.nextInt(110),20+r.nextInt(110),20+r.nextInt(110)));gc.drawString(rn,13*i+6,16);}*/gc.setColor(new Color(20 + r.nextInt(110), 20 + r.nextInt(110),20 + r.nextInt(110)));gc.drawString(RS, 10, 16);// 释放图形上下文环境gc.dispose();// 将认证码RS存入SESSION中共享session.setAttribute("random", RS);// 输出生成后的验证码图像到页面ImageIO.write(pic, "JPEG", response.getOutputStream());}//Process the HTTP Post requestpublic void doPost(HttpServletRequest request, HttpServletResponse response) throwsServletException, IOException {doGet(request, response);}//Clean up resourcespublic void destroy() {}
}

        显示生成的验证码:

                <img src="${pageContext.request.contextPath}/RandomCodeController" />

      

         生成的验证码在session对象中存储:

                  session.setAttribute("random", RS) ;       
         

         "看不清",点击事件相关操作: 重新给图片设置src属性值:
               

      $("#codeImg").attr("src",$("#path").val()+"/RandomCodeController?t="+Math.random())

这篇关于day84 json中实现简单验证码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/946795

相关文章

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入