注册--验证码制作

灰太狼 2022-01-27 01:59 428阅读 0赞

1.input 输入框和验证码图片(src 属性引入图片):

  1. <input id="code" name="code" type="text" class="chen_txt yanzm" placeholder="验证码" onblur="checkCode()">
  2. <div>
  3. <img id="captchaImg" style="CURSOR: pointer" onclick="changeCaptcha()"
  4. title="看不清楚?请点击刷新验证码!" align='absmiddle' src="${ctx}/captchaServlet"
  5. height="18" width="55">
  6. <a href="javascript:;"
  7. onClick="changeCaptcha()" style="color: #666;">看不清楚</a>
  8. <span id="code_span" style="color: red"></span>
  9. </div>

代码解读如下:
(1)onclick 点击事件 changeCaptcha() 方法,点击之后 更换验证码,具体方法如下:

  1. function changeCaptcha(){
  2. $("#captchaImg").attr('src','${ctx}/captchaServlet?t=' + (new Date().getTime()));
  3. }

注:${ctx} 指的是 ${pageContext.request.contextPath }

根据 id(captchaImg) 获取 image 标签对象,将它的 src 属性值替换成新的验证码图片。

(2)src 属性值对应的是一个Servlet ,Servlet 对应的URL是 /captchaServlet,当页面加载的时候它会调用该 Servlet 的方法,返回一个验证码图片。

在 web.xml 文件中配置 captchaServlet

  1. <!--验证码-->
  2. <servlet>
  3. <servlet-name>CaptchaServlet</servlet-name>
  4. <servlet-class>
  5. chen.www.common.CodeCaptchaServlet
  6. </servlet-class>
  7. </servlet>
  8. <servlet-mapping>
  9. <servlet-name>CaptchaServlet</servlet-name>
  10. <url-pattern>/captchaServlet</url-pattern>
  11. </servlet-mapping>

调用 captchaServlet 的过程:
(1)根据 URL /captchaServlet 找到名为 CaptchaServlet 的 Servlet。
(2)然后根据名字 CaptchaServlet 找到具体的 Servlet 位置,就可以调用其中的方法返回验证码图片。

3.在 common 包下引入 CodeCaptchaServlet.java,制作验证码的类,主要是通过 Graphics 设置图片大小,然后随机生成干扰点和4位随机验证码,并保存到 Session 中,用于注册时验证。生成验证码的 CodeCaptchaServlet.java 文件,可以当作工具类来直接使用。

  1. package chen.www.common;
  2. import javax.imageio.ImageIO;
  3. import javax.servlet.ServletException;
  4. import javax.servlet.http.HttpServlet;
  5. import javax.servlet.http.HttpServletRequest;
  6. import javax.servlet.http.HttpServletResponse;
  7. import java.awt.*;
  8. import java.awt.image.BufferedImage;
  9. import java.io.IOException;
  10. import java.util.Random;
  11. public class CodeCaptchaServlet extends HttpServlet {
  12. public static final String VERCODE_KEY = "VERCODE_KEY";
  13. @Override
  14. protected void doGet(HttpServletRequest request, HttpServletResponse response)
  15. throws ServletException, IOException {
  16. // request.getSession().removeAttribute(LOGIN_VERCODE_KEY);
  17. request.getSession().removeAttribute(VERCODE_KEY);
  18. // 首先设置页面不缓存
  19. response.setHeader("Pragma", "No-cache");
  20. response.setHeader("Cache-Control", "no-cache");
  21. response.setDateHeader("Expires", 0);
  22. //在内存中创建图象
  23. int iWidth = 55, iHeight = 18;
  24. BufferedImage image = new BufferedImage(iWidth, iHeight,
  25. BufferedImage.TYPE_INT_RGB);
  26. //获取图形上下文
  27. Graphics g = image.getGraphics();
  28. //设定背景色
  29. g.setColor(Color.white);
  30. g.fillRect(0, 0, iWidth, iHeight);
  31. //画边框
  32. g.setColor(Color.black);
  33. g.drawRect(0, 0, iWidth - 1, iHeight - 1);
  34. //取随机产生的认证码(4位数字)
  35. //String rand = Utils.getCharacterAndNumber(4);
  36. int intCount=0;
  37. intCount=(new Random()).nextInt(9999);//
  38. if(intCount <1000)intCount+=1000;
  39. String rand=intCount+"";
  40. //将认证码显示到图象中
  41. g.setColor(Color.black);
  42. g.setFont(new Font("Times New Roman", Font.PLAIN, 18));
  43. g.drawString(rand, 5, 15);
  44. //随机产生88个干扰点,使图象中的认证码不易被其它程序探测到
  45. Random random = new Random();
  46. for (int iIndex = 0; iIndex < 100; iIndex++) {
  47. int x = random.nextInt(iWidth);
  48. int y = random.nextInt(iHeight);
  49. g.drawLine(x, y, x, y);
  50. }
  51. // 将生成的随机字符串写入session
  52. // request.getSession().setAttribute(LOGIN_VERCODE_KEY, rand);
  53. request.getSession().setAttribute(VERCODE_KEY, rand);
  54. //图象生效
  55. g.dispose();
  56. //输出图象到页面
  57. ImageIO.write(image, "JPEG", response.getOutputStream());
  58. }
  59. @Override
  60. protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  61. throws ServletException, IOException {
  62. super.doPost(req, resp);
  63. }
  64. @Override
  65. public void init()
  66. throws ServletException {
  67. super.init();
  68. }
  69. private static final long serialVersionUID = 5413310437308046316L;
  70. }

发表评论

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

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

相关阅读

    相关 java制作简单验证验证程序

    > 在平时,我们登录一些网站或者软件时经常会让我们填写验证码,通过输入验证码功能可以防止:恶意破解密码、刷票、论坛灌水,有效防止某个黑客对某一个特定注册用户用特定程序暴力破解方

    相关 JavaWeb---制作验证

    说起验证码,绝壁是个让人蛋疼的问题,特别是节假日在12306上面抢票的时候遇到的外星系验证码,大大降低了用户的体验度! 可是还是要知道验证码为什么存在,其作用是什