成都网站建设设计

将想法与焦点和您一起共享

jspservletjquery实现图片验证码的异步刷新

近日 ,遇到和验证码问题,在网上找了很多资料加自己的总结,得到可实现代码

成都创新互联公司坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、成都做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的舟山网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

login.jsp代码

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




oa自动化办公系统



	$(function() {
		$("#verifyimg").click(function() {
			$.get("/soa/identCodeServlet.do", function(data) {
			        //此处是刷新的关键
				$("#verifyimg").attr("src", "/soa/identCodeServlet.do");
			});
		});
	});



	
		

oa自动办公系统

登陆
用户名:密  码:验证码:

IdentCodeServlet.java 代码

package com.eduask.oa.servlet;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.p_w_picpath.BufferedImage;
import java.io.IOException;

import javax.p_w_picpathio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.eduask.oa.util.CreateRandomCode;

/**
 * 将生成的验证码作为图片输出
 * @author Maibenben
 *
 */
public class IdentCodeServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;

	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		//1. 禁止浏览器缓存随机图片
		response.setDateHeader("Expires", -1);
		response.setHeader("Cache-Control", "no-cache");
		response.setHeader("Pragma", "no-cache");
		
		//2.通知服务器以图片的方式发送数据
		response.setHeader("Content-Type", "p_w_picpath/jpeg");
		
		//3.在内存创建一张图片
		BufferedImage p_w_picpath = new BufferedImage(150, 50, BufferedImage.TYPE_INT_BGR);
		
		//4.向图片上写数据
		Graphics g = p_w_picpath.getGraphics();
		
		//5.设置背景色
		g.setColor(Color.gray);
		g.fillRect(0, 0, 150, 50);
		
		//6. 设置写入数据的颜色和字体
		g.setColor(Color.red);
		g.setFont(new Font(null, Font.BOLD, 50));
		
		// 7.想图片上写数据
		String randomNum = new CreateRandomCode().createRandomCode();
		request.getSession().setAttribute("checkRandomCode", randomNum);
		g.drawString(randomNum, 20, 40);
		System.out.println(randomNum);
		// 8.把写好的图片输出到浏览器
		ImageIO.write(p_w_picpath, "jpg", response.getOutputStream());
	}
}

生成4位随机验证码代码 CreateRandomCode.java

package com.eduask.oa.util;
/**
 * 随机产生4位 数字或字母混合
 * @author Maibenben
 *
 */
public class CreateRandomCode {
	private char[] code = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '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'};
	
	/**
	 * 生成4位验证码
	 * @return
	 */
	public String createRandomCode() {
		char[] codeRandom = new char[4];
		//循环取得其中随机字符
		for(int i=0; i< codeRandom.length; i++) {
			int random = (int)(Math.random()*code.length);
			codeRandom[i] = code[random];
		}
		//将字符数组转为String
		StringBuffer sb = new StringBuffer();
		for(int i=0; i

这只是简单的验证码图片刷新,希望可以帮到正在寻找答案的你


文章标题:jspservletjquery实现图片验证码的异步刷新
文章链接:http://chengdu.cdxwcx.cn/article/gjgcph.html

其他资讯