登录生成随机验证码

港控/mmm° 2021-10-08 07:08 592阅读 0赞

点击创业

登录+验证码。

验证码生成是单独的一个servlet,通过web.xml进行拦截。

先贴web.xml配置代码,很简单。

[html] view plain copy

  1. /CheckCode
  2. com.wswhr.LoginServer.servlet.CheckCode
  3. /CheckCode
  4. /CheckCode

然后,是这个checkCode的代码。

[java] view plain copy

  1. package com.wswhr.LoginServer.servlet;
  2. import java.awt.Color;
  3. import java.awt.Font;
  4. import java.awt.Graphics;
  5. import java.awt.image.BufferedImage;
  6. import java.io.ByteArrayOutputStream;
  7. import java.io.IOException;
  8. import javax.imageio.ImageIO;
  9. import javax.servlet.ServletException;
  10. import javax.servlet.ServletOutputStream;
  11. import javax.servlet.http.HttpServlet;
  12. import javax.servlet.http.HttpServletRequest;
  13. import javax.servlet.http.HttpServletResponse;
  14. import javax.servlet.http.HttpSession;
  15. //import cn.com.daxtech.framework.security.UidPwdAuthenticationFilter;
  16. @SuppressWarnings(“serial”)
  17. public class CheckCode extends HttpServlet
  18. {
  19. private static int WIDTH = 60;
  20. private static int HEIGHT = 20;
  21. public void doGet(HttpServletRequest request, HttpServletResponse response)
  22. throws ServletException, IOException {
  23. HttpSession session = request.getSession();
  24. response.setContentType(“image/jpeg”);
  25. ServletOutputStream sos = response.getOutputStream();
  26. // 设置浏览器不要缓存此图片
  27. response.setHeader(“Pragma”, “No-cache”);
  28. response.setHeader(“Cache-Control”, “no-cache”);
  29. response.setDateHeader(“Expires”, 0);
  30. // 创建内存图象并获得其图形上下文
  31. BufferedImage image = new BufferedImage(WIDTH, HEIGHT,
  32. BufferedImage.TYPE_INT_RGB);
  33. Graphics g = image.getGraphics();
  34. // 产生随机的认证码
  35. char[] rands = generateCheckCode();
  36. // 产生图像
  37. drawBackground(g);
  38. drawRands(g, rands);
  39. // 结束图像 的绘制 过程, 完成图像
  40. g.dispose();
  41. // 将图像输出到客户端
  42. ByteArrayOutputStream bos = new ByteArrayOutputStream();
  43. ImageIO.write(image, “JPEG”, bos);
  44. byte[] buf = bos.toByteArray();
  45. response.setContentLength(buf.length);
  46. // 下面的语句也可写成: bos.writeTo(sos);
  47. sos.write(buf);
  48. bos.close();
  49. sos.close();
  50. // 将当前验证码存入到 Session 中
  51. session.setAttribute(“validateCode”, new String(rands));
  52. //session.setAttribute(UidPwdAuthenticationFilter.VALIDATE_CODE, new String(rands));
  53. // 直接使用下面的代码将有问题, Session 对象必须在提交响应前获得
  54. //request.getSession().setAttribute(“check_code”,new String(rands));
  55. }
  56. private char[] generateCheckCode() {
  57. // 定义验证码的字符表
  58. String chars = “2345678abcdefghjkmnprstuwxz”;
  59. char[] rands = new char[4];
  60. for (int i = 0; i < 4; i++) {
  61. int rand = (int) (Math.random() * chars.length());
  62. rands[i] = chars.charAt(rand);
  63. }
  64. return rands;
  65. }
  66. private void drawRands(Graphics g, char[] rands) {
  67. g.setColor(Color.BLACK);
  68. g.setFont(new Font(null, Font.ITALIC | Font.BOLD, 18));
  69. // 在不同的高度上输出验证码的每个字符
  70. g.drawString(“” + rands[0], 1, 17);
  71. g.drawString(“” + rands[1], 16, 15);
  72. g.drawString(“” + rands[2], 31, 18);
  73. g.drawString(“” + rands[3], 46, 16);
  74. // System.out.println(rands);
  75. }
  76. private void drawBackground(Graphics g) {
  77. // 画背景
  78. g.setColor(new Color(0xDCDCDC));
  79. g.fillRect(0, 0, WIDTH, HEIGHT);
  80. // 随机产生 120 个干扰点
  81. for (int i = 0; i < 120; i++) {
  82. int x = (int) (Math.random() * WIDTH);
  83. int y = (int) (Math.random() * HEIGHT);
  84. int red = (int) (Math.random() * 255);
  85. int green = (int) (Math.random() * 255);
  86. int blue = (int) (Math.random() * 255);
  87. g.setColor(new Color(red, green, blue));
  88. g.drawOval(x, y, 1, 0);
  89. }
  90. }
  91. }

最后,是使用验证码的jsp代码,以及JS代码

  1. <label>
  2. <span>
  3. <span class="lbl input-icon input-icon-right">
  4. <input id="validateCode" name="validateCode" type="text" class="span12"
  5. maxlength="15" placeholder="验证码" />
  6. <i class="icon-retweet">
  7. </i>
  8. </span>
  9. <span class="lbl">
  10. <img src="${ctx}/CheckCode" id="yzmPic" οnclick="reloadCheckCode()" style="cursor:pointer;"
  11. title="点击刷新验证码" />
  12. <a href="#" οnclick="reloadCheckCode()" data-action="reload">
  13. <i class="icon-refresh">
  14. </i>
  15. </a>
  16. </span>
  17. </span>
  18. </label>

js代码如下:

[html] view plain copy

  1. function reloadCheckCode(){
  2. document.getElementById(“yzmPic”).src = $(“#ctx”).val()+”/CheckCode?r=” + new Date().getTime();
  3. }

最后的 r= new Date().getTime(); 相当于,生成一个随机数,避免缓存, 否则,在servlet中,会一直生成同一个验证码(并不是没有生成,而是一直生成同一个。)

[html] view plain copy

发表评论

表情:
评论列表 (有 0 条评论,592人围观)

还没有评论,来说两句吧...

相关阅读