SpringMVC 加入 Kaptcha 實現(xiàn)圖片驗證碼

加入依賴
<!-- Kaptcha 驗證碼插件 -->
<dependency>
    <groupId>com.github.penggle</groupId>
    <artifactId>kaptcha</artifactId>
    <version>2.3.2</version>
</dependency>
在 spring-mvc.xml 中加入
    <!-- Kaptcha 圖片驗證碼 -->
    <bean id="chptchaProducer" 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">45</prop>
                        <prop key="kaptcha.textproducer.font.size">45</prop>
                        <prop key="kaptcha.session.key">code</prop>
                        <!-- 
                        <prop key="kaptcha.textproducer.char.string">abcdfkgujtmei123456789</prop>
                         -->
                        <prop key="kaptcha.textproducer.char.length">4</prop>
                        <prop key="kaptcha.textproducer.font.names">宋體幻妓,楷體钧萍,微軟雅黑</prop>
                    </props>
                </constructor-arg>
            </bean>     
        </property>
    </bean>

屬性具體配置:http://www.reibang.com/p/e6c71bc37759


文本實現(xiàn)類:kaptcha.textproducer.impl 值為:com.google.code.kaptcha.text.impl.DefaultTextCreator

驗證碼值配置:kaptcha.textproducer.char.string 值:abcde2345678gfynmnpwx(隨意你自己寫)

驗證碼的長度:kaptcha.textproducer.char.length 值:

字體:kaptcha.textproducer.font.names 值:Arial,Courier

字體顏色:kaptcha.textproducer.font.color 值: r,g,b 或者 white,black,blue

文字間隔:kaptcha.textproducer.char.space 值:

干擾實現(xiàn)類:kaptcha.noise.impl 值:com.google.code.kaptcha.impl.DefaultNoise/NoNoise

干擾顏色:kaptcha.noise.color 值: r,g,b 或者 white,black,blue

圖片樣式:kaptcha.obscurificator.impl 值:

水紋com.google.code.kaptcha.impl.WaterRipple甚带;

魚眼com.google.code.kaptcha.impl.FishEyeGimpy优俘;

陰影com.google.code.kaptcha.impl.ShadowGimpy

背景實現(xiàn)類:kaptcha.background.impl 值:com.google.code.kaptcha.impl.DefaultBackground

背景漸變色開始:kaptcha.background.clear.from 值:r,g,b 或者 white,black,blue

背景漸變色結束:kaptcha.background.clear.to 值:r,g,b 或者 white,black,blue

文字渲染器:kaptcha.word.impl 值:com.google.code.kaptcha.text.impl.DefaultWordRenderer

session中存放驗證碼的key鍵:kaptcha.session.key 值:KAPTCHA_SESSION_KEY

Contro;;er 中實現(xiàn)
/**
     * 驗證碼生成
     * @param request
     * @param response
     * @return
     * @throws IOException
     */
    @RequestMapping(value="/captcha-image")
    public ModelAndView getKaptchaImage(HttpServletRequest request, HttpServletResponse response) throws IOException {
        
        System.out.println(request);
        System.out.println(response);
        // 從 session 獲取驗證碼的 code 值
        HttpSession session = request.getSession();
        System.out.println(session);
        String code = (String) session.getAttribute(Constants.KAPTCHA_SESSION_KEY);
        System.out.println(code);
        
        // 設置清除瀏覽器的緩存
        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/png");
        
        // 設置 session 
        String capText = captchaProducer.createText();
        System.out.println("設置session:" + capText);
        session.setAttribute(Constants.KAPTCHA_SESSION_KEY, capText);
        
        // 輸出驗證碼
        BufferedImage bi = captchaProducer.createImage(capText);
        ServletOutputStream out = response.getOutputStream();
        ImageIO.write(bi, "png", out);
        out.flush();
        out.close();
        
        return null;
    }

    /**
     * 驗證碼校驗
     * @param request
     * @param response
     * @param code_j
     * @return
     * @throws Exception
     */
    @RequestMapping("/codeCheck")
    public String codeCheck(HttpServletRequest request, HttpServletResponse response,
            @RequestParam("code")String code_j) throws Exception {
        
        HttpSession session = request.getSession();
        String code = (String) session.getAttribute(Constants.KAPTCHA_SESSION_KEY);
        JSONObject json = new JSONObject();
        if (code_j.equals(code)) {
            json.put("ok", true);
        } else {
            json.put("ok", false);
        }
        ResponseUtil.write(response, json);
        return null;
    }
JSP 頁面
<tr>
    <td>驗證碼:</td>
    <td><input id="j_code" type="text" name="j_code" onblur="javascript:codeCheck()"></td>
    ![](${path }/test/captcha-image)
    <a href="javascript:chageCode()">看不清?換一張</a>
</tr>

    <script type="text/javascript">
        
        // 刷新驗證碼
        function chageCode() {
            var time = new Date().getTime();
            $("#kaptchaImage").attr('src', '${path }/test/captcha-image?id='+time);
        }

              // Ajax 驗證驗證碼
        function codeCheck() {
            var code = $('#inputImagecode').val();
            $.post(
                '${path}/codeCheck',
                {
                    'code' : code
                },
                function(result) {
                    if(result.ok) {
                        //alert("驗證碼正確谬晕!");
                        $('#inputImagecode').css('background-color', 'rgba(91, 255, 173, 0.2)')
                        $('#submitbtn').addAttr('onsubmit');
                    } else {
                        //alert("驗證碼錯誤宿亡!");
                        $('#inputImagecode').css('background-color', 'rgba(255, 81, 81, 0.2)')
                        $('#submitbtn').removeAttr('onsubmit');
                    }
                }, 'json');
        }

    </script>
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市彪腔,隨后出現(xiàn)的幾起案子侥锦,更是在濱河造成了極大的恐慌,老刑警劉巖德挣,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件恭垦,死亡現(xiàn)場離奇詭異,居然都是意外死亡格嗅,警方通過查閱死者的電腦和手機番挺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屯掖,“玉大人玄柏,你說我怎么就攤上這事√” “怎么了粪摘?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長绍坝。 經(jīng)常有香客問我赶熟,道長,這世上最難降的妖魔是什么陷嘴? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任映砖,我火速辦了婚禮,結果婚禮上灾挨,老公的妹妹穿的比我還像新娘邑退。我一直安慰自己,他們只是感情好劳澄,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布地技。 她就那樣靜靜地躺著,像睡著了一般秒拔。 火紅的嫁衣襯著肌膚如雪莫矗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天,我揣著相機與錄音作谚,去河邊找鬼三娩。 笑死,一個胖子當著我的面吹牛妹懒,可吹牛的內(nèi)容都是我干的雀监。 我是一名探鬼主播,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼眨唬,長吁一口氣:“原來是場噩夢啊……” “哼会前!你這毒婦竟也來了?” 一聲冷哼從身側響起匾竿,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤瓦宜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后岭妖,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體临庇,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年区转,在試婚紗的時候發(fā)現(xiàn)自己被綠了苔巨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡废离,死狀恐怖侄泽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蜻韭,我是刑警寧澤悼尾,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站肖方,受9級特大地震影響闺魏,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜俯画,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一析桥、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧艰垂,春花似錦泡仗、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至胰柑,卻和暖如春截亦,著一層夾襖步出監(jiān)牢的瞬間爬泥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工崩瓤, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留袍啡,地道東北人。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓谷遂,卻偏偏與公主長得像葬馋,于是被迫代替她去往敵國和親卖鲤。 傳聞我的和親對象是個殘疾皇子肾扰,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 驗證碼定義:驗證碼是一種區(qū)分用戶是計算機還是人的公共自動程序。作用:可以防止惡意破解密碼蛋逾,刷票集晚、論壇灌水,有效防止...
    年少懵懂丶流年夢閱讀 780評論 0 1
  • 幾次閑談發(fā)現(xiàn)区匣,即使世界復雜多變偷拔、困難重重,仍然有人如魚得水亏钩、游刃有余莲绰,取得令人艷羨的成就。這些人都是“有心人”:時...
    陽光玉豆閱讀 511評論 0 2
  • 在家鄉(xiāng)的夏末,我拖著碩大笨拙的行李箱來到北方栅哀,落地便已入秋震肮。 適應新生活,心總也飄忽不定留拾。北方出了名的干燥讓我...
    大臉象閱讀 494評論 11 1
  • 在互聯(lián)網(wǎng)潮流下戳晌,一個新的用戶需求就會拉動軟件系統(tǒng)的更新?lián)Q代和變革,不更新?lián)Q代的軟件在群控市場是沒有競爭力的痴柔。兔客服...
    xiaoyi166閱讀 222評論 0 0
  • 司徒來到距離前廳最遠的后花園沦偎,才敢開口問話,因為他知道巫月的聽力非同一般咳蔚。 侍從悄聲回復豪嚎,剛才在去穹宮送飯的路...
    夷夏傳說閱讀 291評論 0 2