生成验证码插件kaptcha的使用(jsp中)

web。xml的配置

<!-- 生成验证码配置 -->
    <servlet>
        <servlet-name>Kaptcha</servlet-name>
        <servlet-class>com.google.code.kaptcha.servlet.KaptchaServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>Kaptcha</servlet-name>
        <url-pattern>/kaptcha.jpg</url-pattern>
    </servlet-mapping>   

jsp页面

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <base href="<%=basePath%>">
    
    <title>My JSP 'yanzhengma.jsp' starting page</title>
    
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">    
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>

  </head>
 
  <body>
    <form action="<%=path %>/users/yanzhengma.do">
         <input type="text" name="kaptcha" value="" />
         <img src="kaptcha.jpg" id="kaptchaImage"/>
         <input type="submit" value="提交">
    </form>
    <script type="text/javascript">
        $(function(){
            $('#kaptchaImage').click(function () {
                $(this).attr('src', '<%=basePath%>/kaptcha.jpg?' + Math.floor(Math.random()*100) );
            })
        });
    </script>
    <br /><small>Can't read the image? Click it to get a new one.</small>
  </body>
</html>

后台控制器验证

    @RequestMapping("/yanzhengma.do")
    public String yanzhengma() {
        String kaptchaExpected = (String) request.getSession().getAttribute(
                "key");
        String kaptchaReceived = request.getParameter("kaptcha");
        System.out.println("kaptchaExpected=" + kaptchaExpected + " "
                + "kaptchaReceived=" + kaptchaReceived);
        if (kaptchaReceived == null
                || !kaptchaReceived.equalsIgnoreCase(kaptchaExpected)) {
            return "error";
        }
        return "ok";
    }

验证码图片使用默认的样式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值