java生成动态gif格式与png格式的验证码(代码5)

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
/**
 * 流操作类
 * @author wzztestin
 *
 */
public class Streams {
	/**
	 * 关闭输入流
	 * 
	 * @param in
	 *            输入流
	 */
	public static void close(InputStream in) {
		if (in != null) {
			try {
				in.close();
			} catch (IOException ioex) {
				// ignore
			}
		}
	}

	/**
	 * 关闭输出流
	 * 
	 * @param out
	 *            输出流
	 */
	public static void close(OutputStream out) {
		if (out != null) {
			try {
				out.flush();
			} catch (IOException ioex) {
				// ignore
			}
			try {
				out.close();
			} catch (IOException ioex) {
				// ignore
			}
		}
	}
}

 

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import com.microcare.framework.logs.Logit;

/**
 * 新的验证码
 * @author wzztestin
 *
 */
public class NewYanZHengMa extends HttpServlet {
	/**
	 * 
	 */
	private static final long serialVersionUID = -1434521774502002007L;

	private static String AUTH_CODE_KEY = "fraudrand";

	public void init() throws ServletException {
		super.init();
	}
	
	/**
	 * 生成验证码
	 */
	@SuppressWarnings("static-access")
	public void doGet(HttpServletRequest request, 
			HttpServletResponse response) throws ServletException, IOException {
		response.setHeader("Pragma", "No-cache");
		response.setHeader("Cache-Control", "no-cache");
		response.setDateHeader("Expires", 0);
		response.setContentType("image/jpeg");
		Captcha captcha = new GifCaptcha(150,40,5);
		captcha.getVilidCode();
		int svalue = 0;
		if("+".equals(captcha.getCzfu())){
			svalue = Integer.parseInt(captcha.getOnenum()) + Integer.parseInt(captcha.getTwonum());
		}else{
			svalue = Integer.parseInt(captcha.getOnenum()) - Integer.parseInt(captcha.getTwonum());
		}
		setAuthCode(request, svalue+"");
		Logit.errorLog("newyzm "+this.getAuthCode(request));
		ServletOutputStream out = response.getOutputStream();
        captcha.out(out);
        out.flush();  
        return;
	}
	
	/**
	 * 得到验证码的值
	 * @param request
	 * @return
	 */
	public static String getAuthCode(HttpServletRequest request) {
		String result = null;
		if (request == null) {
			Logit.errorLog("request is null!");
			return result;
		}
		HttpSession session = request.getSession(false);
		if (session == null) {
			Logit.errorLog("session is null!");
			return result;
		}
		if (session.getAttribute(AUTH_CODE_KEY) != null) {
			result = (String)session.getAttribute(AUTH_CODE_KEY);		
		}
		return result;
	}
	
	/**
	 * 把值存入session中
	 * @param request
	 * @param authCode
	 */
	public static void setAuthCode(HttpServletRequest request, String authCode) {
		if (request == null || authCode == null) {
			Logit.errorLog("request/authCode is null!");
			return;
		}
		HttpSession session = request.getSession(true);
		if (session == null) {
			Logit.errorLog("session is null!");
			return;
		}
		session.setAttribute(AUTH_CODE_KEY, authCode);		
	}
	
	/**
	 * 移除验证码
	 * @param request
	 */
	public static void removeAuthCode(HttpServletRequest request) {
		if (request == null) {
			Logit.errorLog("request is null!");
			return;
		}
		HttpSession session = request.getSession(false);
		if (session == null) {
			Logit.errorLog("session is null!");
			return;
		}		
		session.removeAttribute(AUTH_CODE_KEY);
	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值