使用Spring-MVC框架生成验证码

  1. 导入依赖包——kaptcha-2.3.2-jdk14.jar

  2. 在Spring-mvc配置文件中加入以下代码

<!-- 验证码产生器配置  -->
    <bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha">
        <property name="config">
            <bean class="com.google.code.kaptcha.util.Config">
                <constructor-arg>
                    <props>
                        <prop key="kaptcha.border">yes</prop>
                        <prop key="kaptcha.border.color">105,179,90</prop>
                        <prop key="kaptcha.textproducer.font.color">blue</prop>
                        <prop key="kaptcha.image.width">100</prop>
                        <prop key="kaptcha.image.height">60</prop>
                        <prop key="kaptcha.textproducer.font.size">45</prop>
                        <prop key="kaptcha.session.key">code</prop>
                        <prop key="kaptcha.textproducer.char.length">4</prop>
                        <prop key="kaptcha.textproducer.font.names">宋体,楷体,微软雅黑</prop>
                    </props>
                </constructor-arg>
            </bean>
        </property>
    </bean>

3.html代码

    <div class="checkcode">
                <input type="text" id="codetext" placeholder="验证码" maxlength="4"
                    class="login_txtbx"><input id="vcode" type="image" alt="验证码"
                    src="captcha-image.do" onclick="changeCode()"></input>
            </div>

4.js脚本

/**
 * 获取验证码
 */
function changeCode() {
    $("#vcode").attr('src',
            'captcha-image.do?' + Math.floor(Math.random() * 100));
}

5.controller层

package com.xinrui.hospital.action;

import java.awt.image.BufferedImage;
import java.io.IOException;

import javax.annotation.Resource;
import javax.imageio.ImageIO;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

import com.google.code.kaptcha.Producer;
import com.xinrui.hospital.service.impl.AdminServiceImpl;
import com.xinrui.hospital.util.Constants;
import com.xinrui.hospital.util.PrintWriterUtil;

/**
 * 
 * @ClassName: LoginController
 * @Description: 登陆控制类
 * @author 梁志成
 * @date 2016年3月17日 下午11:08:51
 *
 */
@Controller
public class LoginController {

    /**
     * 自动装载验证码产生器
     */
    @Autowired
    private Producer captchaProducer = null;

    /**
     * 
     * @Title: getKaptchaImage
     * @Description: 生成图片验证码
     * @param @param request
     * @param @param response
     * @param @throws Exception
     * @return void
     * @throws
     */
    @RequestMapping(value = "captcha-image")
    public void getKaptchaImage(HttpServletRequest request,
            HttpServletResponse response) throws Exception {
        HttpSession session = request.getSession();

        // 禁止图像缓存
        response.setDateHeader("Expires", 0);
        response.setHeader("Cache-Control",
                "no-store, no-cache, must-revalidate");
        response.addHeader("Cache-Control", "post-check=0, pre-check=0");
        response.setHeader("Pragma", "no-cache");
        response.setContentType("image/jpeg");

        String capText = captchaProducer.createText();
        session.setAttribute(Constants.KAPTCHA_SESSION_KEY, capText);

        BufferedImage bi = captchaProducer.createImage(capText);
        ServletOutputStream out = response.getOutputStream();

        // 将内存中的图片通过流动形式输出到客户端
        ImageIO.write(bi, "jpg", out);
        try {
            out.flush();
        } finally {
            out.close();
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

两只橙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值