验证码
1.java类MakeCert 生成验证码
- package com.certCode;
- 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;
- /**
- * 生成验证图片
- * @author 郑平
- *
- */
- public class MakeCert {
- //图片验证可能出现的字符
- private char mapTable[]={
- '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'};
- /**
- * 功能:生成彩色验证码图片
- * 参数width为生成图片的宽度,参数height为生成图片的高度,参数os为页面的输出流
- */
- public String getCertcode(int width,int height,OutputStream os) {
- if(width<=0){
- width = 60;
- }
- if(height<=0){
- height = 20;
- }
- BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
- //获取图形上下文
- Graphics g = image.getGraphics();
- //设置 背景颜色
- g.setColor(new Color(0xDCDCDC));
- g.fillRect(0, 0, width, height);
- //画边框
- g.setColor(Color.black);
- g.drawRect(0, 0, width-1, height-1);
- String strEnsure = "";
- for(int i=0;i<4;i++){
- //随机产生的验证码
- strEnsure += mapTable[(int)(mapTable.length*Math.random())];
- }
- System.out.println("strEnsure:"+strEnsure);
- //将验证码显示到图片上
- g.setFont(new Font("Atlantic Inline",Font.PLAIN,18));
- String str = strEnsure.substring(0, 1);
- g.drawString(str, 8, 17);
- str = strEnsure.substring(1,2);
- g.drawString(str,20,15);
- str = strEnsure.substring(2,3);
- g.drawString(str,35,18);
- str = strEnsure.substring(3,4);
- g.drawString(str,45,15);
- // 随机产生10个干扰点
- Random r = new Random();
- for(int i =0;i<10;i++){
- int x = r.nextInt(width);
- int y = r.nextInt(height);
- g.drawOval(x, y, 1, 1);
- }
- // 释放图形上下文
- g.dispose();
- try {
- ImageIO.write(image, "JPEG", os);
- } catch (IOException e) {
- // TODO Auto-generated catch block'
- return "";
- }
- return strEnsure;
- }
- }
2.makeCert.jsp jsp调用java类得到验证码 将生成的验证码存在session里面
- <%@ page contentType="image/jpeg; charset=gb2312"
- pageEncoding="utf-8"%>
- <jsp:useBean id="image" scope="page" class="com.certCode.MakeCert"></jsp:useBean>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>验证</title>
- </head>
- <body>
- <%
- String str=image.getCertcode(0,0,response.getOutputStream());
- session.setAttribute("certCode", str);
- out.clear();
- out = pageContext.pushBody();
- %>
- </body>
- </html>
3.login.jsp 登录界面jsp
- <%@ page language="java" contentType="text/html; charset=gb2312"
- pageEncoding="utf-8"%>
- <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
- <html>
- <head>
- <script type="text/javascript">
- function reloadcode() {
- var s = document.getElementById("code");
- s.setAttribute('src','makeCert.jsp?it='+Math.random());
- }
- </script>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
- <title>登录</title>
- </head>
- <body>
- <form action="login">
- 账号:<input type="text" id="id" name="id">
- 验证码:<input type="text" id="certCode"name="certCode">
- <img alt="看不清楚,换一张" src="makeCert.jsp" id="code" οnclick="reloadcode()" style="cursor:pointer;">
- <input type="submit" value="确定">
- </form>
- </body>
- </html>