1
0
mirror of https://github.com/whvcse/EasyCaptcha.git synced 2024-11-23 01:59:19 +08:00
Java图形验证码,支持gif、中文、算术等类型,可用于Java Web、JavaSE等项目。不支持OpenJDK
Go to file
2018-07-27 15:11:34 +08:00
.idea 修复验证码位数的bug,优化代码 2018-07-27 12:02:33 +08:00
src 优化验证码的效果和干扰 2018-07-27 15:11:34 +08:00
.gitignore 修复验证码位数的bug,优化代码 2018-07-27 12:02:33 +08:00
EasyCaptcha.iml 修复验证码位数的bug,优化代码 2018-07-27 12:02:33 +08:00
LICENSE Initial commit 2018-02-11 14:46:59 +08:00
pom.xml 优化验证码的效果和干扰 2018-07-27 15:11:34 +08:00
README.md Update README.md 2018-05-15 08:33:57 +08:00

EasyCaptcha

JavaWeb图形验证码支持gif验证码可用于基于的session的web项目和前后端分离的项目。

效果展示

验证码 刷新页面可以重新生成验证码图片。   

导入项目

gradle方式的引入

需要先在project的build.gradle中添加

allprojects {
    repositories {
        maven { url 'https://jitpack.io' }
    }
}

在项目的build.gradle中添加

dependencies {
    compile 'com.github.whvcse:EasyCaptcha:1.1.0'
}

maven方式引入

<repositories>
    <repository>
    <id>jitpack.io</id>
    <url>https://jitpack.io</url>
    </repository>
</repositories>

<dependencies>
   <dependency>
      <groupId>com.github.whvcse</groupId>
      <artifactId>EasyCaptcha</artifactId>
      <version>1.1.0</version>
   </dependency>
</dependencies>

jar包下载

EasyCaptcha-1.1.0.jar

使用方法

快速使用

1.在web.xml里面加入如下配置

<!-- 图形验证码 -->
<servlet>
    <servlet-name>CaptchaServlet</servlet-name>
    <servlet-class>com.wf.captcha.servlet.CaptchaServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>CaptchaServlet</servlet-name>
    <url-pattern>/images/captcha</url-pattern>
</servlet-mapping>

2.前端代码

<img src="/images/captcha" />

SpringMVC中使用

如果你不想使用项目提供的servlet可以使用controller的形式实现方法也很简单代码如下

@RequestMapping("/images/captcha")
public void captcha(HttpServletRequest request, HttpServletResponse response) {
    CaptchaUtil captcha = new CaptchaUtil();
    try {
        captcha.out(request, response);
    } catch (IOException e) {
        e.printStackTrace();
    }
}

前端代码:

<img src="/images/captcha" />

前后端分离中使用

验证码一般都是保存在session中的但是在前后端分离的项目中不推荐使用session存储可使用如下方式

@RequestMapping("/images/captcha")
public void captcha(String key, HttpServletRequest request, HttpServletResponse response) {
    CaptchaUtil captcha = new CaptchaUtil();
    try {
        captcha.out(key, request, response);
    } catch (IOException e) {
        e.printStackTrace();
    }
}

与前面的使用区别就在于多了一个key使用的时候需要前端生成一个随机key传递过来服务器是已这个key为名字存储在servletContext中的取的时候需要根据这个key取值。

前后端分离也同样可以使用框架自带的servlet使用方式如下

<img src="/images/captcha?key=xxx" />
<!-- 此处的key应该有js随机生成并且js在验证的时候也需要传递这个key -->

判断验证码是否正确

基于session存储的判断

CaptchaUtil captcha = new CaptchaUtil();
if (captcha == null || !captcha.ver(code, request)) {
    return JsonResult.error("验证码不正确");
}

前后端分离方式的判断:

CaptchaUtil captcha = new CaptchaUtil();
if (captcha == null || !captcha.ver(key, code, request)) {
    return JsonResult.error("验证码不正确");
}
//此处的key便是生成的时候传递的key

参数设置

设置宽高和位数

//三个参数分别是宽、高、位数
CaptchaUtil captcha = new CaptchaUtil(130, 38, 5);

修改存储时候的key

CaptchaUtil captcha = new CaptchaUtil();
captcha.setCodeName("captcha");

默认存在session中是以captcha为key存储的存储在servletContext中是以captcha-xxx为key存储的xxx是生成的时候前端传递的key。