springMVC實(shí)現(xiàn)圖形驗(yàn)證碼(kaptcha)代碼實(shí)例
springMVC項(xiàng)目中實(shí)現(xiàn)圖形驗(yàn)證碼功能,可以使用kaptcha來(lái)實(shí)現(xiàn),下面是步驟
一、引入架包,pom.xml
<dependency> <groupId>com.google.code</groupId> <artifactId>kaptcha</artifactId> <version>2.3.2</version> </dependency>
二、kaptchaProducer配置,需要在spring-mvc.xml中對(duì)kaptchaProducer的bean進(jìn)行配置,可以對(duì)驗(yàn)證碼圖形的屬性進(jìn)行配置,網(wǎng)上也有很多可以參考的,我這是放我項(xiàng)目中的相關(guān)代碼
<!-- 使用Kaptcha生成驗(yàn)證碼 --> <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">125</prop> <prop key="kaptcha.image.height">60</prop> <prop key="kaptcha.textproducer.font.size">40</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>
三、kaptchaProducer配置完畢后,就只可以寫(xiě)生成驗(yàn)證碼的方法了。
@Autowired private Producer captchaProducer = null; /** * 生成驗(yàn)證碼 * @param request * @param response * @throws IOException */ @RequestMapping("/yzmImg") public void yzmImg(HttpServletRequest request,HttpServletResponse response) throws IOException{ log.info("-----生成驗(yàn)證碼-----"); HttpSession session = request.getSession(); String preCode = (String)session.getAttribute(Constants.KAPTCHA_SESSION_KEY); log.info("-----生成驗(yàn)證碼-----前一個(gè)驗(yàn)證碼:"+preCode); System.out.println("-----生成驗(yàn)證碼-----前一個(gè)驗(yàn)證碼:"+preCode); //生成驗(yàn)證碼 response.setDateHeader("Expires", 0); // Set standard HTTP/1.1 no-cache headers. response.setHeader("Cache-Control", "no-store, no-cache, must-revalidate"); // Set IE extended HTTP/1.1 no-cache headers (use addHeader). response.addHeader("Cache-Control", "post-check=0, pre-check=0"); // Set standard HTTP/1.0 no-cache header. response.setHeader("Pragma", "no-cache"); // return a jpeg response.setContentType("image/jpeg"); // create the text for the image String capText = captchaProducer.createText(); System.err.println(capText); // store the text in the session session.setAttribute(Constants.KAPTCHA_SESSION_KEY, capText); session.setAttribute(Constants.KAPTCHA_SESSION_DATE, new Date()); // 存放到緩存服務(wù)器上,并把key記錄到cookie //CodeUtils.creatCode(capText, response, request); // create the image with the text BufferedImage bi = captchaProducer.createImage(capText); ServletOutputStream out = response.getOutputStream(); // write the data out ImageIO.write(bi, "jpg", out); try { out.flush(); } finally { out.close(); } }
四、生成驗(yàn)證碼的方法寫(xiě)完后,前端可以使用img標(biāo)簽作為圖形驗(yàn)證碼的容器
jsp代碼
<img src="yzmImg.htm" onclick="getYZMImg()" id="yzmimg">
javascript代碼
function getYZMImg(){ $("#yzmimg").attr("src","yzmImg.htm"); }
img作為圖形的容器,src寫(xiě)生成驗(yàn)證碼的映射,如果需要換一個(gè)驗(yàn)證碼,點(diǎn)擊圖片,onclick事件重新調(diào)用生成驗(yàn)證碼的方法,即可達(dá)到更換驗(yàn)證碼。
下面說(shuō)下我遇到的幾個(gè)問(wèn)題
一、異常,異常信息
Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'com.google.code.kaptcha.Producer' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
我說(shuō)下具體的情況,代碼我寫(xiě)完了之后,就啟動(dòng)服務(wù),可是報(bào)了上面的異常,可是我仔細(xì)檢查了,代碼都沒(méi)有問(wèn)題,但就是拋異常,最后在類的前面加了兩個(gè)注解
@Controller @Scope("prototype") @SuppressWarnings("all") public class IndexController { }
其中Scope和SuppressWarnings兩個(gè)注解加上之后,啟動(dòng)服務(wù)就不會(huì)拋這個(gè)異常了。
二、異常,上面的異常解決之后,又出現(xiàn)了下面這個(gè)異常
java.lang.NoClassDefFoundError: com/jhlabs/image/RippleFilter] with root cause java.lang.ClassNotFoundException: com.jhlabs.image.RippleFilter
提示RippleFilter類找不到,所以加入Filter架包,我是直接加入的架包,架包名為:filters-2.0.235-1.jar,加入這個(gè)架包就不會(huì)拋異常了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Hadoop2.8.1完全分布式環(huán)境搭建過(guò)程
本文搭建了一個(gè)由三節(jié)點(diǎn)(master、slave1、slave2)構(gòu)成的Hadoop完全分布式集群(區(qū)別單節(jié)點(diǎn)偽分布式集群),并通過(guò)Hadoop分布式計(jì)算的一個(gè)示例測(cè)試集群的正確性。對(duì)hadoop分布式環(huán)境搭建過(guò)程感興趣的朋友跟隨小編一起看看吧2019-06-06spring boot整合mybatis利用Mysql實(shí)現(xiàn)主鍵UUID的方法
這篇文章主要給大家介紹了關(guān)于spring boot整合mybatis利用Mysql實(shí)現(xiàn)主鍵UUID的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03Spring Boot整合RabbitMQ開(kāi)發(fā)實(shí)戰(zhàn)詳解
這篇文章主要介紹了Spring Boot整合RabbitMQ開(kāi)發(fā)實(shí)戰(zhàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-02-02Eolink上傳文件到Java后臺(tái)進(jìn)行處理的示例代碼
這篇文章主要介紹了Eolink上傳文件到Java后臺(tái)進(jìn)行處理,這里是上傳的excel表格數(shù)據(jù)并轉(zhuǎn)換為java集合對(duì)象、然后進(jìn)行業(yè)務(wù)邏輯處理判斷最后保存到數(shù)據(jù)庫(kù)?,需要的朋友可以參考下2022-12-12