JSP作业5:servlet应用--图片验证码

作业类型:验证性实验

实验目的:掌握Servlet在JSP开发中的应用

实验内容:使用Servlet实现网页验证码功能。

1. 编写一个Servlet,实现以下功能:

1)能够响应来自客户端的GET请求,不响应POST和其他请求;

2)请求的url-pattern为“/checkcode”;

3)响应请求时,向浏览器改善验证码图片,验证码由4位字符组成,字符可以是26个英文字母和10个数字。

4)同时将验证码字符串放入session中,以便将来客户端提交验证码时检查是否一致。

2. 编写一个login.jsp(见下图),测试验证码是否有效。

1)用户输入正确的验证码,则提示验证码正确;否则提示错误。然后继续显示一个新的验证码。

2)用户点击验证码图片时,更换一个新的验证码。

1.CheckCode.java

package june;
/**验证码实现思路:
*在Servlet中随机产生验证码字符序列,并计入session中,
*JSP中以图片的形式进行显示。当用户在JSP表单中输入验证码并提交时,
*在相应的Servlet中验证是否与session中保存的验证码一致。
*/
import java.awt.*;
import java.awt.image.BufferedImage;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.annotation.WebServlet;
import javax.servlet.annotation.WebInitParam;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
//注释配置Servlet
@WebServlet(name = "StoreCode", urlPatterns = { "/storecode" }, initParams = {
  @WebInitParam(name = "width", value = "80"),
  @WebInitParam(name = "height", value = "30"),
  @WebInitParam(name = "codeCount", value = "4") })
public class StoreCode extends HttpServlet {
 private static final long serialVersionUID = 1L;
 private int width = 80; // 验证码图片的宽
 private int height = 30; // 验证码图片的高
 private int codeCount = 4; // 验证码图片的字符数
 private int x = 16;
 private int fontHeight=22;
 private int codeY=22;
 private final char[] codeSequence = { 'A', 'B', 'C', 'D', 'E', 'F', 'G',
   'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
   'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6',
   '7', '8', '9' };
 
 protected void doGet(HttpServletRequest request,
   HttpServletResponse response) throws ServletException,
   java.io.IOException {
  //构造一个类型为预定义图像类型之一的BufferedImage,设置图像的宽,高,和类型(TYPE_INT_RGB)
  BufferedImage Img = new BufferedImage(width, height,
    BufferedImage.TYPE_INT_RGB);
  
  // 返回Graphics2D,Graphics2D类扩展自Graphics 类,以提供对几何形状、坐标转换、颜色管理和文本布局更为复杂的控制
  Graphics g = Img.getGraphics();
  
  Random random = new Random();
  // 将图像填充为白色
  g.setColor(Color.WHITE);
  //填充指定的矩形。x,y坐标均为0,宽为width,高为height
  g.fillRect(0, 0, width, height);
  // 创建字体,字体的大小应该根据图片的高度来定。
  Font font = new Font("Times new Roman", Font.PLAIN, fontHeight);
  g.setColor(Color.black);
  g.setFont(font);
  Color juneFont = new Color(153, 204, 102);
  // 随机产生130条干扰线,不易被其它程序探测
  g.setColor( juneFont );
  for (int i = 0; i < 130; i++) {
   
   //返回伪随机数
   int x= random.nextInt(width);
   int y = random.nextInt(height);
   int xl = random.nextInt(16);  //80/5=16
   int yl = random.nextInt(16);
   //在此图形上下文的坐标系中,使用当前颜色在点 (x1, y1) 和 (x2, y2) 之间画一条线
   g.drawLine(x, y, x + xl, y + yl);
   
  }
  // randomCode用于保存随机产生的验证码,以便用户登录后进行验证,线程安全的可变字符序列
  StringBuffer randomCode = new StringBuffer();
  // 随机产生codeCount数字的验证码
  for (int i = 0; i < codeCount; i++) {
   //返回 char 参数的字符串表示形式
   String strRand = String.valueOf(codeSequence[random.nextInt(36)]);
   
   // 用随机产生的颜色将验证码绘制到图像中
   //创建具有指定红色、绿色和蓝色值的不透明的 sRGB 颜色,这些值都在 (0 - 255) 的范围内
   g.setColor(new Color(20 + random.nextInt(110), 20 + random
     .nextInt(110), 20 + random.nextInt(110)));
   
   //使用此图形上下文的当前字体和颜色绘制由指定 string 给定的文本。最左侧字符的基线位于此图形上下文坐标系的 (x, y) 位置处。
   g.drawString(strRand, (i + 1) * x-4, codeY);
   randomCode.append(strRand);
  }
  HttpSession session = request.getSession(); // 将四位数字的验证码保存到Session中
  session.setAttribute("realcode", randomCode.toString());
  // 禁止浏览器缓存
  response.setHeader("Pragma", "no-cache");    //HTTP   1.0
  response.setHeader("Cache-Control", "no-cache");//HTTP   1.1
  response.setDateHeader("Expires", 0);      //在代理服务器端防止缓冲
  response.setContentType("image/gif");      //设置正被发往客户端的响应的内容类型
  
  // 将图像输出到Servlet输出流中,ServletOutputStream提供了向客户端发送二进制数据的输出流
  ServletOutputStream sos = response.getOutputStream();
  ImageIO.write(Img, "gif", sos);           //使用支持给定格式的任意 ImageWriter 将一个图像写入 OutputStream
  sos.flush();                    //刷新此输出流并强制写出所有缓冲的输出字节
  sos.close();
 }
}

2.还有login.jsp还有css布局省略,写

<%@ page language="java" contentType="text/html; charset=UTF-8"
 pageEncoding="UTF-8" import="java.util.*"%>
<%@ page import="java.io.PrintWriter" import="java.lang.String"%>
<!DOCTYPE HTML>
<html>
<head>
<title>验证码</title>
<meta charset="UTF-8">
<link rel="stylesheet" href="css/all.css">
</head>
<body>
 <div class="page-back">
  <div class="page-welcome">
   <span class="font-welcome">JSP作业5:Servlet应用</span>
  </div>
  <div class="page-main">
   <div class="page-check">
    <form name="form1" method="get" onsubmit="#">
     <ul>
      <li class="input-info">输入验证码:</li>
      <li><input type="text" id="input-code" name="input-code">
       <!-- 点击一下重新加载一次验证码 --> <input type="image" name="img-code"
       id="img-code" alt="看不清,点击换图" src="checkcode"
       onclick="javascript:this.src='checkcode?+rand=Math.random()'"></li>
      <li><input type="submit" value="验证" id="check-button"
       onclick="#"></li>
      <li><%
       String realCode = request.getSession().getAttribute("realcode").toString();
       if (request.getParameter("input-code") != null) {
        String userCode = request.getParameter("input-code");
        PrintWriter output = response.getWriter();//创建输出流对象
        if (userCode.equalsIgnoreCase(realCode)) {
         out.print("&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;输入正确");
        } else {
         out.print("&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;输入错误,请重新输入!");
        }
       }
      %>
      </li>
     </ul>
    </form>
   </div>
  </div>
  <div class="page-footer">
   <p>Copyright ? 2014 All Rights Reserved</p>
   <p>
    Author:June(王映君) &nbsp;&nbsp; <a
     href="http://my.oschina.net/june6502/blog">博客链接:</a>
   </p>
  </div>
 </div>
</body>
</html>

页面效果:

JSP作业5:servlet应用--图片验证码_第1张图片

你可能感兴趣的:(jsp,servlet,图片验证码)