• 技术文章 >Java >java教程

    登陆时验证码结合springboot的用法实例介绍

    零下一度零下一度2017-06-17 11:48:06原创802
    在一个web应用中验证码是一个常见的元素。不管是防止机器人还是爬虫都有一定的作用,下面这篇文章主要给大家介绍了登陆验证码kaptcha结合spring boot用法的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。

    前言

    在我们用户登录的时候,为了安全性考虑,会增加验证码的功能,这里采用的是google的kaptcha;spirngboot是轻便,独立,使得基于spring的应用开发变得特别简单。网上有很多介绍springboot的介绍,这里不多说。

    言归正抓,讲下登陆时验证码结合springboot的用法

    引入kaptcha所需要的jar包,我这里用的是maven


      <dependency> 
       <groupId>com.github.penggle</groupId> 
       <artifactId>kaptcha</artifactId> 
       <version>2.3.2</version> 
        
       <exclusions> 
        <exclusion> 
         <artifactId>javax.servlet-api</artifactId> 
         <groupId>javax.servlet</groupId> 
        </exclusion> 
       </exclusions> 
      </dependency>

    去除包中自带的servlet包。在我个人的理解中springboot就是javaconfig和注解搭建起来的轻型的微架构。

    下面是kapcha的javaconfig


    @Configuration 
    public class CaptchaConfig { 
      
     
     @Bean(name="captchaProducer") 
     public DefaultKaptcha getKaptchaBean(){ 
      DefaultKaptcha defaultKaptcha=new DefaultKaptcha(); 
      Properties properties=new Properties(); 
      properties.setProperty("kaptcha.border", "yes"); 
      properties.setProperty("kaptcha.border.color", "105,179,90"); 
      properties.setProperty("kaptcha.textproducer.font.color", "blue"); 
      properties.setProperty("kaptcha.image.width", "125"); 
      properties.setProperty("kaptcha.image.height", "45"); 
      properties.setProperty("kaptcha.session.key", "code"); 
      properties.setProperty("kaptcha.textproducer.char.length", "4"); 
      properties.setProperty("kaptcha.textproducer.font.names", "宋体,楷体,微软雅黑");   
      Config config=new Config(properties); 
      defaultKaptcha.setConfig(config); 
      return defaultKaptcha; 
     } 
    }

    这里的的katcha的javaconfig相当于springmvc中的bean配置,下面给是一个针对上面javaconfig的springmvc的bean示例,供参考


    <bean id="captchaProducer" class="com.google.code.kaptcha.impl.DefaultKaptcha"> 
      <property name="config"> 
       <bean class="com.google.code.kaptcha.util.Config"> 
        <constructor-arg> 
         <props> 
          <prop key="kaptcha.border">yes</prop> 
          <prop key="kaptcha.border.color">105,179,90</prop> 
          <prop key="kaptcha.textproducer.font.color">blue</prop> 
          <prop key="kaptcha.image.width">125</prop> 
          <prop key="kaptcha.image.height">45</prop> 
          <prop key="kaptcha.textproducer.font.size">45</prop> 
          <prop key="kaptcha.session.key">code</prop> 
          <prop key="kaptcha.textproducer.char.length">4</prop> 
          <prop key="kaptcha.textproducer.font.names">宋体,楷体,微软雅黑</prop> 
         </props> 
        </constructor-arg> 
       </bean> 
      </property> 
     </bean>

    其中构造方法中的属性参数可以根据自己的需求来设置。

    配置文件已经配好,那么如何获取自己的二维码呢,我的理解是画布的概念,然后将生成的四位的验证码生成对应的画布,然后让结果write出去。

    代码如下:


    @RequestMapping(value = "/captcha-image") 
     public ModelAndView getKaptchaImage(HttpServletRequest request, 
       HttpServletResponse response) throws Exception { 
      response.setDateHeader("Expires", 0); 
      response.setHeader("Cache-Control", 
        "no-store, no-cache, must-revalidate"); 
      response.addHeader("Cache-Control", "post-check=0, pre-check=0"); 
      response.setHeader("Pragma", "no-cache"); 
      response.setContentType("image/jpeg"); 
     
      String capText = captchaProducer.createText(); 
      System.out.println("capText: " + capText); 
     
      try { 
       String uuid=UUIDUtils.getUUID32().trim().toString();    
       redisTemplate.opsForValue().set(uuid, capText,60*5,TimeUnit.SECONDS); 
       Cookie cookie = new Cookie("captchaCode",uuid); 
       response.addCookie(cookie); 
      } catch (Exception e) { 
       e.printStackTrace(); 
      } 
     
       
     
      BufferedImage bi = captchaProducer.createImage(capText); 
      ServletOutputStream out = response.getOutputStream(); 
      ImageIO.write(bi, "jpg", out); 
      try { 
       out.flush(); 
      } finally { 
       out.close(); 
      } 
      return null; 
     }

    如上面的代码,在用户登录的时候使用验证码以及cooike中的captchacode来实现唯一性验证,开始的时候我考虑到放到session中,当时想了下,感觉这不科学啊,比如讲captchacode放到session中,这时候验证码是一个,后来另一个用户再登陆,前一个用户还在登陆中,这时候会出现一系列的问题。这里使用cookie和redis,来应对用户的并发登陆验证。

    页面使用也比较简单如下:


    <p style="float: left;"> 
      <i><img style="height:22px;" id="codeImg" alt="点击更换" title="点击更换" src="code/captcha-image" /></i> 
    </p>

    更换的话加一个click事件,然后清空以前在redis中对应的缓存数据;或者在获取验证码的时候,设置生存周期。

    以上就是登陆时验证码结合springboot的用法实例介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    上一篇:详解Spark中将对象序列化存储到hdfs 下一篇:分享Spring Batch的介绍
    大前端线上培训班

    相关文章推荐

    • 理解java8中java.util.function.*pojo反射新方法(附代码)• 浅析安卓app和微信授权登录及分享完整对接(代码分享)• 教你一招搞定时序数据库在Spring Boot中的使用• 一招教你使用java快速创建Map(代码分享)• PlayFramework 完整实现一个APP(十一)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网