激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - spring mvc 使用kaptcha配置生成驗證碼實例

spring mvc 使用kaptcha配置生成驗證碼實例

2020-09-13 12:23alee_方 Java教程

本篇文章主要介紹了spring mvc 使用kaptcha生成驗證碼實例,詳細的介紹了使用Kaptcha 生成驗證碼的步驟,有興趣的可以了解一下

使用Kaptcha 生成驗證碼十分簡單并且參數可以進行自定義,以下簡單記錄下使用步驟。

1.在pom.xml中添加maven依賴:

?
1
2
3
4
5
6
<dependency>
  <groupId>com.google.code.kaptcha</groupId>
  <artifactId>kaptcha</artifactId>
  <version>2.3</version>
  <classifier>jdk15</classifier>
</dependency>

2.web.xml中配置kaptcha屬性:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<bean id="verifyCodeProducer" 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.border.thickness">1</prop>
 
            <prop key="kaptcha.noise.color">blue</prop>
 
            <prop key="kaptcha.image.width">150</prop>
            <prop key="kaptcha.image.height">50</prop>
 
            <prop key="kaptcha.session.key">verifyCode</prop>
 
            <!-- <prop key="kaptcha.textproducer.char.string">0123456789abcdefghijklmnopqrst!@#$%^*</prop> -->
            <prop key="kaptcha.textproducer.char.length">4</prop>
            <prop key="kaptcha.textproducer.char.space">4</prop>
 
 
            <prop key="kaptcha.textproducer.font.size">30</prop>
            <prop key="kaptcha.textproducer.font.color">blue</prop>
 
          </props>
        </constructor-arg>
      </bean>
    </property>
  </bean>

其中bean節點的id值 verifyCodeProducer 為在類中引用@Resource生成實例時的名稱;屬性配置中 kaptcha.session.key 的值為在session中存取名稱。

在servlet節點中配置

3.controller類中的相關方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
@Controller
public class CommonController {
 
  @Autowired
  private Producer verifyCodeProducer;
 
  @RequestMapping(path = "/getVerifyCodeImage", method = RequestMethod.GET)
  public void getVerifyCodeImage(HttpServletRequest request, HttpServletResponse response) {
    HttpSession session = request.getSession();
 
    ResponseUtils.noCache(response);
    response.setContentType("image/jpeg");
 
    String capText = verifyCodeProducer.createText();
    session.setAttribute(Constants.SESSION_KEY_VERIFY_CODE, capText);
 
    BufferedImage bi = verifyCodeProducer.createImage(capText);
    ServletOutputStream out = null;
    try {
      out = response.getOutputStream();
      ImageIO.write(bi, "jpg", out);
      out.flush();
    } catch (Exception ex) {
      LOGGER.error("Failed to produce the verify code image: ", ex);
      throw new ServerInternalException("Cannot produce the verify code image.");
    } finally {
      IOUtils.closeQuietly(out);
    }
  }
}

Constants.SESSION_KEY_VERIFY_CODE為屬性配置中 kaptcha.session.key 的值。

4.jsp:

?
1
2
3
4
5
6
7
<div class="form-group has-feedback">
  <span class="glyphicon glyphicon-barcode form-control-feedback"></span>
  <input id="verifyCode" name="verifyCode" type="text" maxlength="4" class="form-control" placeholder="<spring:message code='login.label.code' />" />
  <div style="height: 1px"></div>
  <img src="${pageContext.request.contextPath}/getVerifyCodeImage" id="verifyCodeImage" style="margin-bottom: -3px" />
  <a href="#" rel="external nofollow" onclick="changeVerifyCode()"><spring:message code='login.code.tip' /></a>
</div>
?
1
2
3
4
function changeVerifyCode() {
  $('#verifyCodeImage').hide().attr('src', '${pageContext.request.contextPath}/getVerifyCodeImage?' + Math.floor(Math.random()*100) ).fadeIn();
  event.cancelBubble=true;
}

5.kaptcha屬性說明:

  1. kaptcha.border.color   邊框顏色   默認為Color.BLACK 
  2. kaptcha.border.thickness  邊框粗細度  默認為1 
  3. kaptcha.producer.impl   驗證碼生成器  默認為DefaultKaptcha 
  4. kaptcha.textproducer.impl   驗證碼文本生成器  默認為DefaultTextCreator 
  5. kaptcha.textproducer.char.string   驗證碼文本字符內容范圍  默認為abcde2345678gfynmnpwx 
  6. kaptcha.textproducer.char.length   驗證碼文本字符長度  默認為5 
  7. kaptcha.textproducer.font.names    驗證碼文本字體樣式  默認為new Font("Arial", 1, fontSize), new Font("Courier", 1, fontSize) 
  8. kaptcha.textproducer.font.size   驗證碼文本字符大小  默認為40 
  9. kaptcha.textproducer.font.color  驗證碼文本字符顏色  默認為Color.BLACK 
  10. kaptcha.textproducer.char.space  驗證碼文本字符間距  默認為2 
  11. kaptcha.noise.impl    驗證碼噪點生成對象  默認為DefaultNoise 
  12. kaptcha.noise.color   驗證碼噪點顏色   默認為Color.BLACK 
  13. kaptcha.obscurificator.impl   驗證碼樣式引擎  默認為WaterRipple 
  14. kaptcha.word.impl   驗證碼文本字符渲染   默認為DefaultWordRenderer 
  15. kaptcha.background.impl   驗證碼背景生成器   默認為DefaultBackground 
  16. kaptcha.background.clear.from   驗證碼背景顏色漸進   默認為Color.LIGHT_GRAY 
  17. kaptcha.background.clear.to   驗證碼背景顏色漸進   默認為Color.WHITE 
  18. kaptcha.image.width   驗證碼圖片寬度  默認為200 
  19. kaptcha.image.height  驗證碼圖片高度  默認為50  

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/aleefang/article/details/70231335

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费一级特黄毛片 | 成人一级黄色 | 神马久久精品综合 | 国产乱淫av一区二区三区 | 免费国产自久久久久三四区久久 | 99视频有精品| 国产视频在线一区 | 免费毛片播放 | 一级做人爱c黑人影片 | 法国极品成人h版 | av在线播放免费 | 国产成人精品午夜视频' | 黄色网址在线播放 | 欧美成人一区二区三区电影 | 综合在线视频 | 草草免费视频 | 神马久久精品综合 | 护士hd欧美free性xxxx | 成人福利视频网站 | 国产免费高清在线 | 午夜视频你懂的 | 暴力肉体进入hdxxxx0 | 成人精品一区二区三区中文字幕 | 国产精品18久久久久久久 | 亚洲国产精品一区二区久久 | 99久久精品日本一区二区免费 | 成年人精品视频 | 性欧美xxxx极品摘花 | 91久久久久久久久久久久久 | 成人男女视频 | 日本中文字幕网址 | 最新午夜综合福利视频 | 日本在线视频免费 | 午夜国产福利 | 综合网天天色 | 亚洲操比视频 | chinese中国真实乱对白 | 高清成人在线 | 女人解衣喂奶电影 | 香蕉成人在线观看 | 久久丝袜脚交足黄网站免费 |