简介
kaptcha是谷歌开源的简单实用的验证码生成工具。通过设置参数,可以自定义验证码大小、颜色、显示的字符等等。
Maven引入
增加了com.google.code.kaptcha:kaptcha 依赖,pom.xml 配置文件如下:
1 2 3 4 5
   | <dependency> 	<groupId>com.github.axet</groupId> 	<artifactId>kaptcha</artifactId> 	<version>${kaptcha.version}</version> </dependency>
   | 
 
配置
配置类如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
   | import com.google.code.kaptcha.impl.DefaultKaptcha; import com.google.code.kaptcha.util.Config;
 
 
 
 
 
  @Configuration public class KaptchaConfig {
      @Bean     public DefaultKaptcha producer() {         Properties properties = new Properties();         properties.put("kaptcha.border", "no");         properties.put("kaptcha.textproducer.font.color", "black");         properties.put("kaptcha.textproducer.char.space", "5");         Config config = new Config(properties);         DefaultKaptcha defaultKaptcha = new DefaultKaptcha();         defaultKaptcha.setConfig(config);         return defaultKaptcha;     } }
   | 
 
Controller层
Controller 层的相关代码如下,通过captcha.jpg请求验证码,设置验证码文本,返回对应图片;验证登录时会使用该文本信息。
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 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
   | 
 
 
  @Controller public class SysLoginController { 	@Autowired 	private Producer producer; 	 	@RequestMapping("captcha.jpg") 	public void captcha(HttpServletResponse response)throws IOException {         response.setHeader("Cache-Control", "no-store, no-cache");         response.setContentType("image/jpeg");
                   String text = producer.createText();                  BufferedImage image = producer.createImage(text);                  ShiroUtils.setSessionAttribute(Constants.KAPTCHA_SESSION_KEY, text);                  ServletOutputStream out = response.getOutputStream();         ImageIO.write(image, "jpg", out); 	} 	 	
 
  	@ResponseBody 	@RequestMapping(value = "/sys/login", method = RequestMethod.POST) 	public R login(String username, String password, String captcha) { 		String kaptcha = ShiroUtils.getKaptcha(Constants.KAPTCHA_SESSION_KEY); 		if(!captcha.equalsIgnoreCase(kaptcha)){ 			return R.error("验证码不正确"); 		} 		 		try{ 			Subject subject = ShiroUtils.getSubject(); 			UsernamePasswordToken token = new UsernamePasswordToken(username, password); 			subject.login(token); 		}catch (UnknownAccountException e) { 			return R.error(e.getMessage()); 		}catch (IncorrectCredentialsException e) { 			return R.error("账号或密码不正确"); 		}catch (LockedAccountException e) { 			return R.error("账号已被锁定,请联系管理员"); 		}catch (AuthenticationException e) { 			return R.error("账户验证失败"); 		} 	     		return R.ok(); 	}   	 }
 
  | 
 
前端
页面代码如下。
1 2 3 4 5 6 7 8
   | <div class="form-group has-feedback">   <input type="text" class="form-control" v-model="captcha" @keyup.enter="login" placeholder="验证码">   <span class="glyphicon glyphicon-warning-sign form-control-feedback"></span> </div> <div class="form-group has-feedback">   <img alt="如果看不清楚,请单击图片刷新!" class="pointer" :src="src" @click="refreshCode">       <a href="javascript:;" @click="refreshCode">点击刷新</a> </div>
   | 
 
效果图如下
js代码如下
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 31 32 33 34 35 36 37 38 39 40 41 42
   | <script type="text/javascript"> var vm = new Vue({ 	el:'#rrapp', 	data:{ 		username: '', 		password: '', 		captcha: '', 		error: false, 		errorMsg: '', 		src: 'captcha.jpg' 	}, 	beforeCreate: function(){ 		if(self != top){ 			top.location.href = self.location.href; 		} 	}, 	methods: { 		refreshCode: function(){ 			this.src = "captcha.jpg?t=" + $.now(); 		}, 		login: function (event) { 			var data = "username="+vm.username+"&password="+vm.password+"&captcha="+vm.captcha; 			$.ajax({ 				type: "POST", 			    url: "sys/login", 			    data: data, 			    dataType: "json", 			    success: function(result){ 					if(result.code == 0){ 						parent.location.href ='index.html'; 					}else{ 						vm.error = true; 						vm.errorMsg = result.msg; 						 						vm.refreshCode(); 					} 				} 			}); 		} 	} }); </script>
   | 
 
kaptcha配置表
可通过如下参数来自定义验证码
| 配置 | 
描述 | 
| kaptcha.border | 
是否有边框 默认为true 我们可以自己设置yes,no | 
| kaptcha.border.color | 
边框颜色 默认为Color.BLACK | 
| kaptcha.border.thickness | 
边框粗细度 默认为1 | 
| kaptcha.producer.impl | 
验证码生成器 默认为DefaultKaptcha | 
| kaptcha.textproducer.impl | 
验证码文本生成器 默认为DefaultTextCreator | 
| kaptcha.textproducer.char.string | 
验证码文本字符内容范围 默认为abcde2345678gfynmnpwx | 
| kaptcha.textproducer.char.length | 
验证码文本字符长度 默认为5 | 
| kaptcha.textproducer.font.names | 
验证码文本字体样式 默认为new Font(“Arial”, 1, fontSize), new Font(“Courier”, 1, fontSize) | 
| kaptcha.textproducer.font.size | 
验证码文本字符大小 默认为40 | 
| kaptcha.textproducer.font.color | 
验证码文本字符颜色 默认为Color.BLACK | 
| kaptcha.textproducer.char.space | 
验证码文本字符间距 默认为2 | 
| kaptcha.noise.impl | 
验证码噪点生成对象 默认为DefaultNoise | 
| kaptcha.noise.color | 
验证码噪点颜色 默认为Color.BLACK | 
| kaptcha.obscurificator.impl | 
验证码样式引擎 默认为WaterRipple | 
| kaptcha.word.impl | 
验证码文本字符渲染 默认为DefaultWordRenderer | 
| kaptcha.background.impl | 
验证码背景生成器 默认为DefaultBackground | 
| kaptcha.background.clear.from | 
验证码背景颜色渐进 默认为Color.LIGHT_GRAY | 
| kaptcha.background.clear.to | 
验证码背景颜色渐进 默认为Color.WHITE | 
| kaptcha.image.width | 
验证码图片宽度 默认为200 | 
| kaptcha.image.height | 
验证码图片高度 默认为50 | 
| kaptcha.session.key | 
session中存放验证码的key键 | 
参考资料
官方网站
java 实现登录验证码 (kaptcha 验证码组件)