- 创建servlet
- CodeServlet:
- package com.lxs.servlet;
- import java.awt.Color;
- import java.awt.Font;
- import java.awt.Graphics;
- import java.awt.image.BufferedImage;
- import java.io.IOException;
- import java.io.OutputStream;
- import java.util.Random;
- import javax.imageio.ImageIO;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- public class CodeServlet extends HttpServlet {
- private static final long serialVersionUID = 1L;
- protected void service(HttpServletRequest request, HttpServletResponse response)
- throws ServletException, IOException {
- String codes="abcdefghijklmnopqrstuvwxyzABCDEFJHIJKLMNOPQRSTUVWXYZ0123456789";
- BufferedImage img=new BufferedImage(80,30,BufferedImage.TYPE_3BYTE_BGR);
- Graphics g=img.getGraphics();
- //填充图片
- g.setColor(new Color(255,255,255));
- g.fillRect(0, 0, 80, 30);
- //画入五个随机数
- Random rm=new Random();
- StringBuffer sb=new StringBuffer();
- for(int i=0;i<5;i++){
- int index=rm.nextInt(codes.length());
- char code=codes.charAt(index);
- g.setColor(new Color(rm.nextInt(256),rm.nextInt(256),rm.nextInt(256)));
- g.setFont(new Font("宋体", Font.BOLD, 25));
- g.drawString(code+"", 2+15*i, 22);
- sb.append(code);
- }
- //画干扰线
- for(int i=0;i<10;i++){
- g.setColor(new Color(rm.nextInt(256),rm.nextInt(256),rm.nextInt(256)));
- g.drawLine(rm.nextInt(100), rm.nextInt(50), rm.nextInt(100), rm.nextInt(50));
- }
- //将验证码图片回写给浏览器
- response.setContentType("image/jpeg;charset=utf-8");
- OutputStream out=response.getOutputStream();
- ImageIO.write(img, "jpeg", out);
- //将随机字符串保存在session中
- request.getSession().setAttribute("code", sb.toString());
- }
- }
- web-xml
- <servlet-name>CodeServlet</servlet-name>
- <servlet-class>com.yinhe.web.servlet.CodeServlet</servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>CodeServlet</servlet-name>
- <url-pattern>/checkCode</url-pattern>
- </servlet-mapping>
- 前台页面
- <script type="text/javascript">
- function loadImage(){ document.getElementById("randImage").src = "${pageContext.request.contextPath}/image.jsp?"+Math.random(); //Math.random()方法非常重要,它使每次的请求都不同以便重新发送。如果每次的请求都一样,那么不会重新生成页面 }
- </script>
-
- <img src="checkCode" alt="" id="codeImg"
- style="width: 80px; height: 30px; border: 1px solid black;" />
- <a href="javascript:;" οnclick="document.getElementById('codeImg').src = 'checkCode?'+(new Date()).getTime()">换一张</a>
- <span id="codemsg" style="color: red; font-size: 20px;"></span>