EasyCaptcha 使用教程

EasyCaptcha 使用教程

项目地址:https://gitcode.com/gh_mirrors/ea/EasyCaptcha

项目介绍

EasyCaptcha 是一个用于生成图形验证码的 Java 库,支持 GIF、中文、算术等多种类型。它适用于 Java Web 和 JavaSE 项目,提供了丰富的配置选项和内置字体,不依赖系统字体。EasyCaptcha 旨在简化验证码的生成和使用过程,提高开发效率。

项目快速启动

引入依赖

首先,你需要在你的项目中引入 EasyCaptcha 库。以下是通过 Maven 和 Gradle 引入的示例:

Maven
<dependencies>
    <dependency>
        <groupId>com.github.whvcse</groupId>
        <artifactId>easy-captcha</artifactId>
        <version>1.6.2</version>
    </dependency>
</dependencies>
Gradle
dependencies {
    compile 'com.github.whvcse:easy-captcha:1.6.2'
}

生成验证码

以下是一个简单的示例,展示如何生成一个 PNG 验证码并输出到文件:

import com.wf.captcha.SpecCaptcha;
import java.awt.Font;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;

public class Test {
    public static void main(String[] args) throws Exception {
        OutputStream outputStream = new FileOutputStream(new File("D:/a/aa.png"));
        SpecCaptcha specCaptcha = new SpecCaptcha(130, 48, 5);
        specCaptcha.setFont(new Font("Verdana", Font.PLAIN, 32));
        specCaptcha.setCharType(SpecCaptcha.TYPE_ONLY_NUMBER);
        String code = specCaptcha.text();
        specCaptcha.out(outputStream);
    }
}

应用案例和最佳实践

Web 应用中的使用

在 Web 项目中,你可以通过以下方式生成验证码并输出到 HTTP 响应中:

import com.wf.captcha.SpecCaptcha;
import com.wf.captcha.utils.CaptchaUtil;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@RequestMapping("/getcode")
public void captcha(HttpServletRequest request, HttpServletResponse response) throws IOException {
    CaptchaUtil.setHeader(response);
    SpecCaptcha specCaptcha = new SpecCaptcha(85, 45, 4);
    specCaptcha.setCharType(SpecCaptcha.TYPE_ONLY_NUMBER);
    specCaptcha.out(response.getOutputStream());
}

最佳实践

  1. 字体设置:使用内置字体,避免依赖系统字体。
  2. 验证码类型:根据需求选择合适的验证码类型,如纯数字、纯字母或混合类型。
  3. 干扰线:增加贝塞尔曲线作为干扰线,提高安全性。

典型生态项目

EasyCaptcha 可以与以下项目结合使用,以增强验证码功能:

  1. Spring Boot:集成 Spring Boot 快速开发验证码服务。
  2. Shiro/Spring Security:结合安全框架,实现验证码的验证和校验。
  3. Redis:使用 Redis 存储验证码,提高性能和可扩展性。

通过这些生态项目的结合,可以构建出更加健壮和高效的验证码系统。

EasyCaptcha EasyCaptcha 项目地址: https://gitcode.com/gh_mirrors/ea/EasyCaptcha

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

### EasyCaptcha 使用教程和示例 #### 一、项目简介 EasyCaptcha 是一款专为 Java 开发者设计的图形验证码生成库。该工具不仅能够创建静态图片形式的基础验证码,还支持动态 GIF 图片以及包含中文字符或简单数学运算表达式的复杂验证方式[^4]。 #### 二、引入依赖项 对于 Maven 构建工具使用者来说,在项目的 `pom.xml` 文件内添加如下配置即可完成对 EasyCaptcha 的集成: ```xml <dependency> <groupId>com.github.captain-miao</groupId> <artifactId>easy-captcha-core</artifactId> <version>最新版本号</version> </dependency> ``` 而对于 Gradle 用户,则需在 build.gradle 中加入下面这段话来实现相同目的: ```groovy implementation 'com.github.captain-miao:easy-captcha-core:最新版本号' ``` 请注意替换上述代码中的 "最新版本号" 字样为你实际想要使用的具体版本标签。 #### 三、基本用法实例 以下是几个简单的例子展示了如何利用 EasyCaptcha 创建不同类型的验证码对象并将其渲染成图像流返回给客户端浏览器显示。 ##### 1. 默认样式验证码 此部分演示了最基础也是最常见的纯英文字符串组成的四位数随机码生成方法。 ```java // 导入必要的类包 import cn.hutool.captcha.CaptchaUtil; import javax.servlet.http.HttpServletResponse; public class CaptchaExample { public void generateDefaultCaptcha(HttpServletResponse response){ // 创建默认规格的验证码对象,默认长度为4位字母数字混合型 DefaultCaptcha defaultCaptcha = CaptchaUtil.createDefaultCaptcha(); // 将生成好的验证码作为Http响应体发送出去供前端页面展示 CaptchaUtil.out(defaultCaptcha,response); } } ``` ##### 2. 动态GIF格式验证码 如果希望得到更加生动有趣的动画效果,可以尝试使用 GifCaptcha 类来自定义更复杂的视觉体验。 ```java // 同上导入语句... import java.awt.Color; public class GifCaptchaDemo { public void createAnimatedGifCaptcha(HttpServletResponse resp) throws IOException{ // 设置宽度高度颜色数量等参数构建自定义风格的gif验证码 int width=200,height=80,codeCount=4,colorNums=5; Color[] colors={Color.RED,Color.BLUE,Color.GREEN}; // 实例化一个具有指定属性的新 gif 验证码组件 GifCaptcha gifCap=new GifCaptcha(width,height,colors.length); gifCap.setFont(new Font("Arial",Font.BOLD|Font.ITALIC,36)); gifCap.setColor(colors); // 输出到HTTP输出流中呈现于网页端口处 CaptchaUtil.out(gifCap,resp); } } ``` ##### 3. 数学计算题验证码 为了增加破解难度,有时会采用基于四则运算的小题目让用户解答的形式来进行身份认证校验工作。 ```java // ...继续沿用之前的 import 声明... public class ArithmeticQuestionGenerator { private static final Random RAND=new SecureRandom(); /** * @param res ServletResponse 对象用于向 HTTP 请求发起方回传数据 */ public void produceMathProblemAsVerificationCode(HttpServletResponse res)throws Exception{ // 初始化一道加减乘除任意组合而成的一元一次方程式的问答式验证码实体 char op=(char)(RAND.nextInt(4)+'+'); // '+','-','*','/' 四种操作符之一 int numA=RAND.nextInt(90)+1,numB=RAND.nextInt(9)+(op=='/')?numA%10==0?1:numA%10:0; // 确保除法不会出现余数 StringBuilder sb=new StringBuilder().append(numA).append(' ').append(op).append(' ').append(numB); String question=sb.toString(),answer=""; switch (op){ case '+' : answer=Integer.toString(numA+numB);break; case '-' : answer=Integer.toString(numA-numB);break; case '*' : answer=Integer.toString(numA*numB);break; case '/' : answer=Integer.toString(numA/numB);break; } // 利用 Hutool 工具箱里的封装函数直接把问题串与正确答案一起打包进 session 或 cookie 存储起来以便后续验证环节调用对比 HttpSession ses=((HttpServletRequest)((ServletOutputStreamWrapper)res.getOutputStream()).getServletRequest()).getSession(true); ses.setAttribute("captcha_answer",answer.toLowerCase()); // 转换成可视化的文本框配合提示信息一同呈现在界面上引导用户输入相应数值完成挑战流程 PrintWriter out=res.getWriter(); out.println("<div style='font-size:larger;'>"); out.printf("%s=?",question); out.print("</div>"); out.flush();out.close(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

廉欣盼Industrious

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值