登录加入验证码功能
功能 登录 验证码 加入
2023-09-14 09:00:25 时间
刚才网吧没机子,我把一个小学生机子下了 ,我强行上机了。、他说要把我头按在键盘上,逗逼,哈哈哈哈哈,就凭
shsjxhjsnwndkkclswkwjksjhskxkckxkskwnnncmcbsb
以下代码,均可以粘贴复制到任何项目中使用。
登录+验证码。
验证码生成是单独的一个servlet,通过web.xml进行拦截。
先贴web.xml配置代码,很简单。
同一页面生成多个验证码 一个页面需要两个验证码,使用同一个验证码调用两次会导致有前一个失效。那么我们需要创建不同的两个验证码,分别做验证。
学会这个工具的使用,让你快速生成验证码 验证码是我们做人机验证最常用的方式,常用于敏感操作的验证,比如:登录、注册、修改等。 验证码的原理:不同的客户端拥有不同的 session 对象,在看到验证码图片的时刻,服务器后端代码生成图片并将随机字符存储到 session 中。
刚才网吧没机子,我把一个小学生机子下了 ,我强行上机了。、他说要把我头按在键盘上,逗逼,哈哈哈哈哈,就凭
shsjxhjsnwndkkclswkwjksjhskxkckxkskwnnncmcbsb
以下代码,均可以粘贴复制到任何项目中使用。
登录+验证码。
验证码生成是单独的一个servlet,通过web.xml进行拦截。
先贴web.xml配置代码,很简单。
servlet servlet-name /CheckCode /servlet-name servlet-class com.wswhr.LoginServer.servlet.CheckCode /servlet-class /servlet servlet-mapping servlet-name /CheckCode /servlet-name url-pattern /CheckCode /url-pattern /servlet-mapping然后,是这个checkCode的代码。
package com.wswhr.LoginServer.servlet; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt.image.BufferedImage; import java.io.ByteArrayOutputStream; import java.io.IOException; import javax.imageio.ImageIO; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; //import cn.com.daxtech.framework.security.UidPwdAuthenticationFilter; @SuppressWarnings("serial") public class CheckCode extends HttpServlet private static int WIDTH = 60; private static int HEIGHT = 20; public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { HttpSession session = request.getSession(); response.setContentType("image/jpeg"); ServletOutputStream sos = response.getOutputStream(); // 设置浏览器不要缓存此图片 response.setHeader("Pragma", "No-cache"); response.setHeader("Cache-Control", "no-cache"); response.setDateHeader("Expires", 0); // 创建内存图象并获得其图形上下文 BufferedImage image = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB); Graphics g = image.getGraphics(); // 产生随机的认证码 char[] rands = generateCheckCode(); // 产生图像 drawBackground(g); drawRands(g, rands); // 结束图像 的绘制 过程, 完成图像 g.dispose(); // 将图像输出到客户端 ByteArrayOutputStream bos = new ByteArrayOutputStream(); ImageIO.write(image, "JPEG", bos); byte[] buf = bos.toByteArray(); response.setContentLength(buf.length); // 下面的语句也可写成: bos.writeTo(sos); sos.write(buf); bos.close(); sos.close(); // 将当前验证码存入到 Session 中 session.setAttribute("validateCode", new String(rands)); //session.setAttribute(UidPwdAuthenticationFilter.VALIDATE_CODE, new String(rands)); // 直接使用下面的代码将有问题, Session 对象必须在提交响应前获得 //request.getSession().setAttribute("check_code",new String(rands)); private char[] generateCheckCode() { // 定义验证码的字符表 String chars = "2345678abcdefghjkmnprstuwxz"; char[] rands = new char[4]; for (int i = 0; i i++) { int rand = (int) (Math.random() * chars.length()); rands[i] = chars.charAt(rand); return rands; private void drawRands(Graphics g, char[] rands) { g.setColor(Color.BLACK); g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 18)); // 在不同的高度上输出验证码的每个字符 g.drawString("" + rands[0], 1, 17); g.drawString("" + rands[1], 16, 15); g.drawString("" + rands[2], 31, 18); g.drawString("" + rands[3], 46, 16); // System.out.println(rands); private void drawBackground(Graphics g) { // 画背景 g.setColor(new Color(0xDCDCDC)); g.fillRect(0, 0, WIDTH, HEIGHT); // 随机产生 120 个干扰点 for (int i = 0; i 120; i++) { int x = (int) (Math.random() * WIDTH); int y = (int) (Math.random() * HEIGHT); int red = (int) (Math.random() * 255); int green = (int) (Math.random() * 255); int blue = (int) (Math.random() * 255); g.setColor(new Color(red, green, blue)); g.drawOval(x, y, 1, 0);最后,是使用验证码的jsp代码,以及JS代码
label span span input id="validateCode" name="validateCode" type="text" maxlength="15" placeholder="验证码" / i /i /span span img src="${ctx}/CheckCode" id="yzmPic" title="点击刷新验证码"/ a href="#" data-action="reload" i /i /span /span /labeljs代码如下:
function reloadCheckCode(){ document.getElementById("yzmPic").src = $("#ctx").val()+"/CheckCode?r=" + new Date().getTime();最后的 r= new Date().getTime(); 相当于,生成一个随机数,避免缓存, 否则,在servlet中,会一直生成同一个验证码(并不是没有生成,而是一直生成同一个。)
input type="hidden" id="ctx" value="${pageContext.request.contextPath}"/
同一页面生成多个验证码 一个页面需要两个验证码,使用同一个验证码调用两次会导致有前一个失效。那么我们需要创建不同的两个验证码,分别做验证。
学会这个工具的使用,让你快速生成验证码 验证码是我们做人机验证最常用的方式,常用于敏感操作的验证,比如:登录、注册、修改等。 验证码的原理:不同的客户端拥有不同的 session 对象,在看到验证码图片的时刻,服务器后端代码生成图片并将随机字符存储到 session 中。
相关文章
- 【愚公系列】2022年09月 微信小程序-微信小程序实现网页一键登录功能
- 性能测试|电商业务性能测试(二): Jmeter 参数化功能实现注册登录的数据驱动
- 【计算机网络】网络层 : 总结 ( 功能 | 数据交换 | IP 数据报 | IPv4 地址 | IPv6 地址 | 路由选择协议 | 路由算法 )★★★
- Web前端图形验证码登录验证功能
- WPJAM「用户管理插件」新增记录用户最后登录时间功能
- MongoDB 数据库如何开启权限认证配置用户密码登录功能
- 基于Redis无序集合如何实现禁止多端登录功能
- 登录功能:实现PHPMySQL网站注册登录功能(php与mysql注册)
- Linux中关闭用户登录功能(linux关闭用户登陆)
- Win11 Build 22000.100发布:任务栏整合Teams聊天功能等
- 如何启用Firefox 91的Win10单点登录功能
- 管理系统的功能与应用介绍(oracleebs财务)
- 器搭建Oracle服务器,实现新增功能(oracle新建服务)
- 媒体评Apple Pay最主要功能:装
- 功能深入理解SQL Server中的预登录功能(sqlserver预登录)
- 签到系统基于Redis的用户签到功能(签到redis)
- 实现集群功能Redis服务器启动之旅(redis集群服务器启动)
- ajax完美实现两个网页分页功能的实例代码
- jquerycookie实现的简单换肤功能适合小网站