说明
原项目使用的是jcaptcha的maven依赖:
<dependency>
<groupId>com.octo.captcha</groupId>
<artifactId>jcaptcha-all</artifactId>
<version>1.0-RC4</version>
</dependency>
最近发现jar不能再下载了,改成了google的仍旧不好使:
<dependency>
<groupId>com.google.code.kaptcha</groupId>
<artifactId>kaptcha</artifactId>
<version>2.3.2</version>
</dependency>
故只好使用阿里maven仓库的:
<dependency>
<groupId>com.github.penggle</groupId>
<artifactId>kaptcha</artifactId>
<version>2.3.2</version>
</dependency>
不废话了,下面是具体实现步骤:
1- 在pom.xml中添加上述的maven依赖项:
<dependency>
<groupId>com.github.penggle</groupId>
<artifactId>kaptcha</artifactId>
<version>2.3.2</version>
</dependency>
2- 在applicationContext.xml添加配置文件
<bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha">
<property name="config">
<bean class="com.google.code.kaptcha.util.Config">
<constructor-arg>
<props>
<!-- 是否有边框 可选yes 或者 no -->
<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.textproducer.font.size">45</prop>
<!-- 验证码 图片 的宽度 默认为200 -->
<prop key="kaptcha.image.width">125</prop>
<!-- 验证码 图片 的高度 默认为50 -->
<prop key="kaptcha.image.height">45</prop>
<!-- 验证码 文本字符 长度 默认5 -->
<prop key="kaptcha.textproducer.char.length">4</prop>
<!-- 验证码 文本字体 样式 默认为new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize) -->
<prop key="kaptcha.textproducer.font.names">宋体,楷体,微软雅黑</prop>
</props>
</constructor-arg>
</bean>
</property>
</bean>
3- controller中生成验证码
package com.esd.controller.checkcode;
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.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.servlet.ModelAndView;
import com.google.code.kaptcha.Constants;
import com.google.code.kaptcha.Producer;
/**
* 验证码控制器
* @author yufu
* @email feimeideyanggao@126.com
* @date 2018年6月29日 下午1:21:21
*
*/
@Controller
@RequestMapping(value = "/checkcode")
public class CheckCodeController {
private static Logger logger = Logger.getLogger(CheckCodeController.class);
@Resource
private Producer captchaProducer;
// 生成验证码图片
@RequestMapping(value = "/create")
public ModelAndView createCheckCode(HttpServletRequest request, HttpServletResponse response) throws IOException {
HttpSession session = request.getSession();
response.setHeader("Pragma", "no-cache");
response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate");
response.addHeader("Cache-Control", "post-check=0, pre-check=0");
response.setDateHeader("Expires", 0);
response.setContentType("image/jpeg");
// 生成验证码文本字符
String captchaText = captchaProducer.createText();
session.setAttribute(Constants.KAPTCHA_SESSION_KEY, captchaText);
logger.info("captchaText: " + captchaText);
// 用验证码文本创建图片
BufferedImage bi = captchaProducer.createImage(captchaText);
ServletOutputStream out = response.getOutputStream();
ImageIO.write(bi, "jpg", out);
try {
out.flush();
} finally {
out.close();
}
return null;
}
// 校验验证码
@RequestMapping(value = "/check")
@ResponseBody
public Boolean check(@RequestParam(value = "checkcode") String codeStr, HttpServletRequest request,
HttpServletResponse response, HttpSession session) {
String generateCode = (String) request.getSession().getAttribute(Constants.KAPTCHA_SESSION_KEY);
if (generateCode.equalsIgnoreCase(codeStr)) {
return true;
} else {
return false;
}
}
}
4- 前台页面显示
<div>
<img id="verifyCode" src="${contextPath}/checkcode/create" alt="验证码,看不清楚?请点击刷新验证码" οnclick="return getimgcode()" />
<input name="LoginVerifyCode" id="LoginVerifyCode" class="TextInput" maxlength="60" type="text" />
</div>
有点多余的大家都会的刷新验证码的js
// 刷新验证码
function getimgcode(){
var timestamp=new Date().getTime();
$("#verifyCode").attr("src","/checkcode/create?"+timestamp);
}