温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么在JavaWeb中使用Session实现一次性验证码功能

发布时间:2021-04-19 17:44:17 来源:亿速云 阅读:211 作者:Leah 栏目:编程语言

本篇文章为大家展示了怎么在JavaWeb中使用Session实现一次性验证码功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Java是什么

Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序。

表单

<form action="loginServlet" method="post">  请输入验证码:<input type="text" name="code" />  <img src="getCodeServlet" /><br />  <button type="submit">提交</button> </form>

载入页面时,会自动请求getCodeServlet,获取图片(验证码)。

getCodeServlet,产生验证码

@WebServlet("/getCodeServlet") public class GetCodeServlet extends HttpServlet {   //验证码的宽、高   private static int WIDTH=80;   private static int HEIGHT=25;   //绘制背景   private void drawBg(Graphics g){     //rgb     g.setColor(new Color(128, 128, 128));     //绘制矩形。x,y,wigth,height     g.fillRect(0,0,WIDTH,HEIGHT);     //随机绘制100个干扰点     Random random=new Random();     for (int i=0;i<100;i++){       //产生(0,1)上的小数,*WIDTH|HEIGHT,再取整也行       int x=random.nextInt(WIDTH);       int y=random.nextInt(HEIGHT);       g.drawOval(x,y,1,1);       //干扰点的颜色也可以随机,随机产生red,green,blue即可       //g.setColor(new Color(red,green,blue));     }   }   //绘制验证码   private void drawCode(Graphics g,char[] code){     g.setColor(Color.BLACK);     //字体、样式(多个时竖线分隔)、字号     g.setFont(new Font("serif",Font.ITALIC|Font.BOLD,18));     //在不同位置绘制验证码字符,参数:要绘制的String、横、纵坐标。+""是为了char转String。     g.drawString(code[0]+"",1,17);     g.drawString(code[1]+"",16,15);     g.drawString(code[2]+"",31,18);     g.drawString(code[3]+"",46,16);   }   //随机产生4位验证码   private char[] getCode(){     String chars="0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm";     char[] code=new char[4];     Random random=new Random();     for (int i=0;i<4;i++){       //[0,62)       int index= random.nextInt(62);       code[i]=chars.charAt(index);     }     return code;   }   protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {     HttpSession session = request.getSession();     ServletOutputStream sos = response.getOutputStream();     response.setContentType("image/jpeg");     //设置浏览器不缓存此图片     response.setHeader("Pragma","No-cache");     response.setHeader("Cache-Control","no-cache");     response.setDateHeader("Expires",0);     //创建内存图片     BufferedImage bufferedImage = new BufferedImage(WIDTH, HEIGHT, TYPE_INT_RGB);     Graphics g= bufferedImage.getGraphics();     char[] code=getCode();     //将验证码放到session域中。session对象要在提交响应之前获得     session.setAttribute("code",new String(code));     drawBg(g);     drawCode(g,code);     g.dispose();     //将图片输出到浏览器     ByteArrayOutputStream baos = new ByteArrayOutputStream();     ImageIO.write(bufferedImage,"JPEG",baos);     baos.writeTo(sos);     baos.close();     sos.close();   }   protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {     doPost(request,response);   } }

loginServlet,处理表单

@WebServlet("/loginServlet") public class LoginServlet extends HttpServlet {   protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {     response.setContentType("text/html;charset=utf-8");     HttpSession session = request.getSession();     String trueCode= (String) session.getAttribute("code");     String code=request.getParameter("code");     if (code.equals(trueCode)){       response.getWriter().write("验证码正确");     }     else {       response.getWriter().write("验证码错误");     }   }   protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {     doPost(request,response);   } }

上面的处理方式要区分验证码的大小写。

不区分大小写:

//先转换为全大写|全小写,再判断     trueCode=trueCode.toLowerCase();     code=code.toLowerCase();     //trueCode=trueCode.toUpperCase();     //code=trueCode.toUpperCase();

上述内容就是怎么在JavaWeb中使用Session实现一次性验证码功能,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI