文章目录

  • 前言
  • 一、kaptcha默认的图片样式的问题
  • 二、自定义图片效果的步骤
    • 1.创建自定义鱼纹效果类
    • 2.修改kaptcha.xml配置
  • 总结

前言

本文教大家如何自定义kaptcha的图片样式,效果如下:


一、kaptcha默认的图片样式的问题

这里我以鱼眼效果为例,大家看下默认的效果:

从上图大家可以看到,文字变形很严重,不是很好辨认。
下面是xml配置文件:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"><!-- 生成kaptcha的bean--><bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha"><property name="config"><bean class="com.google.code.kaptcha.util.Config"><constructor-arg type="java.util.Properties"><!--设置kaptcha属性 --><props><prop key="kaptcha.border ">yes</prop><prop key="kaptcha.border.color">105,179,90</prop><prop key="kaptcha.textproducer.font.color">black</prop><prop key="kaptcha.image.width">100</prop><prop key="kaptcha.image.height">44</prop><prop key="kaptcha.textproducer.font.size">27</prop><prop key="kaptcha.session.key">code</prop><prop key="kaptcha.textproducer.char.length">4</prop><prop key="kaptcha.textproducer.font.names">Arial, Courier</prop><prop key="kaptcha.textproducer.char.string">0123456789</prop><prop key="kaptcha.obscurificator.impl">com.google.code.kaptcha.impl.FishEyeGimpy</prop><!--                        <prop key="kaptcha.noise.color">black</prop>--><prop key="kaptcha.noise.impl">com.google.code.kaptcha.impl.NoNoise</prop><prop key="kaptcha.textproducer.char.space">3</prop><prop key="kaptcha.textproducer.impl">com.google.code.kaptcha.text.impl.DefaultTextCreator</prop>         </props></constructor-arg></bean></property></bean>
</beans>

其中图片效果用的是com.google.code.kaptcha.impl.FishEyeGimpy

二、自定义图片效果的步骤

这里我还是以鱼纹效果为例

1.创建自定义鱼纹效果类

代码如下(示例):

package com.zjyc.qzaft.entity.customs;import com.google.code.kaptcha.impl.FishEyeGimpy;import java.awt.*;
import java.awt.image.BufferedImage;/*** Author: mek* Date: 2022\5\14 0014* Time: 10:37* Description: 自定义鱼眼纹效果*/
public class AftFishEyeGimpy extends FishEyeGimpy {@Overridepublic BufferedImage getDistortedImage(BufferedImage baseImage) {Graphics2D graph = (Graphics2D)baseImage.getGraphics();int imageHeight = baseImage.getHeight();int imageWidth = baseImage.getWidth();int horizontalLines = imageHeight / 7;int verticalLines = imageWidth / 7;int horizontalGaps = imageHeight / (horizontalLines + 1);int verticalGaps = imageWidth / (verticalLines + 1);int i;for(i = horizontalGaps; i < imageHeight; i += horizontalGaps) {graph.setColor(Color.blue);graph.drawLine(0, i, imageWidth, i);}for(i = verticalGaps; i < imageWidth; i += verticalGaps) {graph.setColor(Color.red);graph.drawLine(i, 0, i, imageHeight);}int[] pix = new int[imageHeight * imageWidth];int j = 0;for(int j1 = 0; j1 < imageWidth; ++j1) {for(int k1 = 0; k1 < imageHeight; ++k1) {pix[j] = baseImage.getRGB(j1, k1);++j;}}/*这里删除了默认鱼纹效果类的渲染代码*/return baseImage;}
}

2.修改kaptcha.xml配置

将图片效果类设置成自己的AftFishEyeGimpy类
代码如下(示例):

<prop key="kaptcha.obscurificator.impl">com.zjyc.qzaft.entity.customs.AftFishEyeGimpy</prop>

总结

自定义图片效果的方法,就是新建类继承默认的效果类,然后重写getDistortedImage函数。

sprintboot验证码kaptcha 自定义图片样式相关推荐

  1. 用python3根据配置自动生成自定义图片logo(一键解决图片侵权困扰)

    欢迎关注原创视频教程 Python微信订餐小程序课程视频 https://edu.csdn.net/course/detail/36074 Python实战量化交易理财系统 https://edu.c ...

  2. 关于图片验证码Kaptcha的应用

    关于Kaptcha的项目应用 应用环境Spring boot + Spring Cloud 首先pom.xml 种注入kaptcha的相关依赖: <dependency> <grou ...

  3. markdown编辑器中去除图片水印以及自定义水印样式

    目录 内容介绍 一.图片链接 1.默认图片 2.参数 3.自定义 二.去除水印 1.删除参数 2.设置字号 内容介绍   csdn的markdown编辑中经常会插入图片,用做代码截图.效果展示等,默认 ...

  4. 验证码-kaptcha

    常见的验证码方案有 kaptcha 等.本篇记录 kaptcha 用法 kaptcha 引入依赖 <!-- https://mvnrepository.com/artifact/com.gith ...

  5. java验证码Kaptcha

    aptcha 是一个可高度配置的实用验证码生成工具 一.最新的maven源 <!-- https://mvnrepository.com/artifact/com.github.penggle/ ...

  6. JAVA google验证码kaptcha 属性配置大全

    property 说明 取值范围 默认值 kaptcha.border 图片边框 yes , no yes kaptcha.border.color 边框颜色 合法值:r,g,b (and optio ...

  7. 验证码 KAPTCHA 参数详解

    原地址:https://www.cnblogs.com/louis80/p/5230507.html Constant 描述 默认值 kaptcha.border 图片边框,合法值:yes , no ...

  8. kaptcha html页面验证码,kaptcha验证码使用(示例代码)

    效果图: kaptcha 是一个很有用的验证码生成工具.有了它,你能够生成各种样式的验证码,由于它是可配置的. kaptcha工作的原理是调用 com.google.code.kaptcha.serv ...

  9. [转]C# winForm 自定义鼠标样式的两种方法

    本文转自:http://www.cnblogs.com/hzbzxm/archive/2008/09/15/1291104.html 以前试过在WinForm中自定义鼠标样式,结果显示出来的鼠标变成单 ...

  10. 用css自定义滚动条样式

    如果你是一个搞网页前端的,有必要了解一下自定义滚动条样式这个东东.目前支持自定义滚动条样式的有IE浏览器.webkit内核浏览器(chrome). IE下的滚动条样式 1.样式规则 scrollbar ...

最新文章

  1. 简单dp ---HDU3485 Count 101
  2. 【PAT乙级】1032 挖掘机技术哪家强 (20 分)
  3. tensorflow随笔-条件循环控制(1)
  4. python树的实现_Python实现简单字典树的方法
  5. sql server 以10分钟分组 统计人数
  6. 【大数据-第二期】java基础第五天作业
  7. 观察者(Observer)模式
  8. C语言 55555图形 找车牌问题
  9. jmeter性能测试~Beanshell
  10. 大数据之路:阿里巴巴大数据实践(数据模型篇)
  11. DELL win10插入耳机后声音仍然外放(亲测有效)
  12. EFF称强行删除代码侵犯人权
  13. 一、26个字母的读音和发音
  14. 第三只眼与另一个世界
  15. html虚线垂直居中,css-虚线边框滚动效果
  16. Datawhale-深入浅出pytorch简介安装和基础知识
  17. JAVA核心知识点--IO流
  18. uva10635Prince and Princess(LIS)
  19. python逻辑运算符的优先级_Python逻辑运算符
  20. html select不允许选择,设置select下拉框不能选择

热门文章

  1. Google Dapper,大规模分布式系统的跟踪系统
  2. 汇佳学校|多元艺术+探究式思维 领航国际艺术教育新趋势
  3. 解决CMU-15-213-ICS的部分lab在部分64位系统WSL中btest无法运行的问题
  4. ROS学习笔记之——amcl源码的解读
  5. 动态Web-JSP和tomcat
  6. 切!原来进入500强就那么简单啊——前IBM,HP,Dell员工揭开外企的招聘内幕
  7. 绘制qq群的基础用例图_首次绘制出“氟化氢”地图:间接实现追踪宇宙中最常见的分子氢!...
  8. HDU多校第六场——HDU6638 Snowy Smile(线段树区间合并)
  9. 1005. F.Snowy Roads最小生成树Kruskal算法
  10. 上周刚号召加班,这周立马双休,董明珠把互联网玩明白了……