整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          SpringBoot-登錄驗證碼實現

          ,工具類記錄

          原鏈接:https://blog.csdn.net/qq_37651267/article/details/99305573,非常感謝原鏈接博主

          此驗證碼的實現沒有用到太多的插件,話不多說直接上代碼,大家拿過去就可以用。

          1.驗證碼類

           package com.youyou.login.util.validatecode;
          
          import lombok.Data;
          
          /**
           * 驗證碼類
           */
          @Data
          public class VerifyCode {
          
              private String code;
          
              private byte[] imgBytes;
          
              private long expireTime;
          
          }
          
          

          2.驗證碼生成接口

           package com.youyou.login.util.validatecode;
          
          import java.io.IOException;
          import java.io.OutputStream;
          
          /**
           * 驗證碼生成接口
           */
          public interface IVerifyCodeGen {
          
              /**
               * 生成驗證碼并返回code,將圖片寫的os中
               *
               * @param width
               * @param height
               * @param os
               * @return
               * @throws IOException
               */
              String generate(int width, int height, OutputStream os) throws IOException;
          
              /**
               * 生成驗證碼對象
               *
               * @param width
               * @param height
               * @return
               * @throws IOException
               */
              VerifyCode generate(int width, int height) throws IOException;
          }
          
          

          3.驗證碼生成實現類

           package com.youyou.login.util.validatecode;
          
          import com.youyou.util.RandomUtils;
          import org.slf4j.Logger;
          import org.slf4j.LoggerFactory;
          
          import javax.imageio.ImageIO;
          import java.awt.*;
          import java.awt.image.BufferedImage;
          import java.io.ByteArrayOutputStream;
          import java.io.IOException;
          import java.io.OutputStream;
          import java.util.Random;
          
          /**
           * 驗證碼實現類
           */
          public class SimpleCharVerifyCodeGenImpl implements IVerifyCodeGen {
          
              private static final Logger logger = LoggerFactory.getLogger(SimpleCharVerifyCodeGenImpl.class);
          
              private static final String[] FONT_TYPES = { "\u5b8b\u4f53", "\u65b0\u5b8b\u4f53", "\u9ed1\u4f53", "\u6977\u4f53", "\u96b6\u4e66" };
          
              private static final int VALICATE_CODE_LENGTH = 4;
          
              /**
               * 設置背景顏色及大小,干擾線
               *
               * @param graphics
               * @param width
               * @param height
               */
              private static void fillBackground(Graphics graphics, int width, int height) {
                  // 填充背景
                  graphics.setColor(Color.WHITE);
                  //設置矩形坐標x y 為0
                  graphics.fillRect(0, 0, width, height);
          
                  // 加入干擾線條
                  for (int i = 0; i < 8; i++) {
                      //設置隨機顏色算法參數
                      graphics.setColor(RandomUtils.randomColor(40, 150));
                      Random random = new Random();
                      int x = random.nextInt(width);
                      int y = random.nextInt(height);
                      int x1 = random.nextInt(width);
                      int y1 = random.nextInt(height);
                      graphics.drawLine(x, y, x1, y1);
                  }
              }
          
              /**
               * 生成隨機字符
               *
               * @param width
               * @param height
               * @param os
               * @return
               * @throws IOException
               */
              @Override
              public String generate(int width, int height, OutputStream os) throws IOException {
                  BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
                  Graphics graphics = image.getGraphics();
                  fillBackground(graphics, width, height);
                  String randomStr = RandomUtils.randomString(VALICATE_CODE_LENGTH);
                  createCharacter(graphics, randomStr);
                  graphics.dispose();
                  //設置JPEG格式
                  ImageIO.write(image, "JPEG", os);
                  return randomStr;
              }
          
              /**
               * 驗證碼生成
               *
               * @param width
               * @param height
               * @return
               */
              @Override
              public VerifyCode generate(int width, int height) {
                  VerifyCode verifyCode = null;
                  try (
                          //將流的初始化放到這里就不需要手動關閉流
                          ByteArrayOutputStream baos = new ByteArrayOutputStream();
                  ) {
                      String code = generate(width, height, baos);
                      verifyCode = new VerifyCode();
                      verifyCode.setCode(code);
                      verifyCode.setImgBytes(baos.toByteArray());
                  } catch (IOException e) {
                      logger.error(e.getMessage(), e);
                      verifyCode = null;
                  }
                  return verifyCode;
              }
          
              /**
               * 設置字符顏色大小
               *
               * @param g
               * @param randomStr
               */
              private void createCharacter(Graphics g, String randomStr) {
                  char[] charArray = randomStr.toCharArray();
                  for (int i = 0; i < charArray.length; i++) {
                      //設置RGB顏色算法參數
                      g.setColor(new Color(50 + RandomUtils.nextInt(100),
                              50 + RandomUtils.nextInt(100), 50 + RandomUtils.nextInt(100)));
                      //設置字體大小,類型
                      g.setFont(new Font(FONT_TYPES[RandomUtils.nextInt(FONT_TYPES.length)], Font.BOLD, 26));
                      //設置x y 坐標
                      g.drawString(String.valueOf(charArray[i]), 15 * i + 5, 19 + RandomUtils.nextInt(8));
                  }
              }
          }
          
          


          4.工具類

           package com.youyou.util;
          
          import java.awt.*;
          import java.util.Random;
          
          public class RandomUtils extends org.apache.commons.lang3.RandomUtils {
          
              private static final char[] CODE_SEQ = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'J',
                      'K', 'L', 'M', 'N', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W',
                      'X', 'Y', 'Z', '2', '3', '4', '5', '6', '7', '8', '9' };
          
              private static final char[] NUMBER_ARRAY = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
          
              private static Random random = new Random();
          
              public static String randomString(int length) {
                  StringBuilder sb = new StringBuilder();
                  for (int i = 0; i < length; i++) {
                      sb.append(String.valueOf(CODE_SEQ[random.nextInt(CODE_SEQ.length)]));
                  }
                  return sb.toString();
              }
          
              public static String randomNumberString(int length) {
                  StringBuilder sb = new StringBuilder();
                  for (int i = 0; i < length; i++) {
                      sb.append(String.valueOf(NUMBER_ARRAY[random.nextInt(NUMBER_ARRAY.length)]));
                  }
                  return sb.toString();
              }
          
              public static Color randomColor(int fc, int bc) {
                  int f = fc;
                  int b = bc;
                  Random random = new Random();
                  if (f > 255) {
                      f = 255;
                  }
                  if (b > 255) {
                      b = 255;
                  }
                  return new Color(f + random.nextInt(b - f), f + random.nextInt(b - f), f + random.nextInt(b - f));
              }
          
              public static int nextInt(int bound) {
                  return random.nextInt(bound);
              }
          }
          
          

          經過以上代碼,我們的驗證碼生成功能基本上已經實現了,現在還需要一個controller來調用它。

               @ApiOperation(value = "驗證碼")
              @GetMapping("/verifyCode")
              public void verifyCode(HttpServletRequest request, HttpServletResponse response) {
                  IVerifyCodeGen iVerifyCodeGen = new SimpleCharVerifyCodeGenImpl();
                  try {
                      //設置長寬
                      VerifyCode verifyCode = iVerifyCodeGen.generate(80, 28);
                      String code = verifyCode.getCode();
                      LOGGER.info(code);
                      //將VerifyCode綁定session
                      request.getSession().setAttribute("VerifyCode", code);
                      //設置響應頭
                      response.setHeader("Pragma", "no-cache");
                      //設置響應頭
                      response.setHeader("Cache-Control", "no-cache");
                      //在代理服務器端防止緩沖
                      response.setDateHeader("Expires", 0);
                      //設置響應內容類型
                      response.setContentType("image/jpeg");
                      response.getOutputStream().write(verifyCode.getImgBytes());
                      response.getOutputStream().flush();
                  } catch (IOException e) {
                      LOGGER.info("", e);
                  }
              }
          

          搞定!后臺編寫到此結束了。那么又會有博友說了:“說好的實現效果呢?”

          好吧,那么我們繼續前端的代碼編寫。

          前端代碼:

           <html>
          <body>
          
          <div>
              <input id="code" placeholder="驗證碼" type="text" class=""
                     style="width:170px">
              <!-- 驗證碼 顯示 -->
              <img οnclick="javascript:getvCode()" id="verifyimg" style="margin-left: 20px;"/>
          </div>
          
          <script type="text/javascript">
              getvCode();
          
              /**
               * 獲取驗證碼
               * 將驗證碼寫到login.html頁面的id = verifyimg 的地方
               */
              function getvCode() {
                  document.getElementById("verifyimg").src = timestamp("http://127.0.0.1:81/verifyCode");
              }
              //為url添加時間戳
               function timestamp(url) {
                  var getTimestamp = new Date().getTime();
                  if (url.indexOf("?") > -1) {
                      url = url + "×tamp=" + getTimestamp
                  } else {
                      url = url + "?timestamp=" + getTimestamp
                  }
                  return url;
              };
          
          
          </script>
          </body>
          
          </html>
          

          可以實現點擊圖片更換驗證碼。

          實現效果:

          ?

          當然文章開頭的截圖是我系統中的截圖,需要大家自己去根據自己的情況去開發前端了。

          ava如何實現驗證碼驗證功能呢?日常生活中,驗證碼隨處可見,他可以在一定程度上保護賬號安全,那么他是怎么實現的呢?

          Java實現驗證碼驗證功能其實非常簡單:用到了一個Graphics類在畫板上繪制字母,隨機選取一定數量的字母隨機生成,然后在畫板上隨機生成幾條干擾線。

          首先,寫一個驗證碼生成幫助類,用來繪制隨機字母:

          接著,創建一個servlet,用來固定圖片大小,以及處理驗證碼的使用場景,以及捕獲頁面生成的驗證碼(捕獲到的二維碼與用戶輸入的驗證碼一致才能通過)。

          接著寫一個HTML注冊頁面用來檢驗一下:

          效果如下圖:

          當點擊刷新頁面的時候,驗證碼也會隨著變化,但我們看不清驗證碼時,只要點擊驗證碼就會刷新,這樣局部的刷新可以用JavaScript來實現。

          在<img src="/demo/verify/regist.do">中,添加一個問號和一串后綴數字,當刷新時讓后綴數字不斷改變,那么形成的驗證碼也會不斷變化,我們可以采用的一種辦法是后綴數字用date代替,date獲取本機時間,時間是隨時變的,這樣就保證了刷新驗證碼可以隨時變化。

          代碼如下:

          文章來源:https://dwz.cn/Xf07as4Q作者:Java團長

          戶手機號注冊源碼分享,首頁獲取驗證碼,調用阿里大魚短信驗證碼,接口thinkphp5.2寫的,可以判斷手機號是否注冊,短信發送是否成功

          1. <!DOCTYPE html>

          2. <html>

          3. <head>

          4. <meta charset="utf-8">

          5. <meta name="viewport" content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/>

          6. <meta name="format-detection" content="telephone=no,email=no,date=no,address=no">

          7. <title>title</title>

          8. <link rel="stylesheet" type="text/css" href="../css/api.css"/>

          9. <link rel="stylesheet" type="text/css" href="../css/style.css" />

          10. <link rel="stylesheet" type="text/css" href="../css/aui.2.0.css" />

          11. </head>

          12. <body>

          13. <div class="aui-content aui-margin-b-15">

          14. <ul class="aui-list aui-form-list">

          15. <li class="aui-list-item">

          16. <div class="aui-list-item-inner">

          17. <div class="aui-list-item-label-icon">

          18. <i class="aui-iconfont aui-icon-mobile"></i>

          19. </div>

          20. <div class="aui-list-item-input">

          21. <input type="text" placeholder="手機號" id="mobile">

          22. </div>

          23. </div>

          24. </li>

          25. <li class="aui-list-item">

          26. <div class="aui-list-item-inner">

          27. <div class="aui-list-item-label-icon">

          28. <i class="aui-iconfont aui-icon-lock"></i>

          29. </div>

          30. <div class="aui-list-item-input">

          31. <input type="text" placeholder="驗證碼" id="code">

          32. </div>

          33. <div class="aui-list-item-label-icon">

          34. <i class="aui-iconfont aui-icon-display"></i>

          35. </div>

          36. </div>

          37. </li>

          38. </ul>

          39. </div>

          40. <div align="center">

          41. <button type="button" onclick="get_code();">

          42. 獲取驗證碼

          43. </button>

          44. <button type="button" onclick="next_reg();">

          45. 下一步

          46. </button>

          47. </div>

          48. </body>

          49. <script type="text/javascript" src="../script/api.js"></script>

          50. <script type="text/javascript">

          51. var mobile = document.getElementById("mobile");

          52. var code = document.getElementById("code");

          53. var code_str = "";

          54. for (var i = 0; i < 6; i++) {

          55. code_str += Math.round(Math.random() * 10);

          56. }


          主站蜘蛛池模板: 成人无码AV一区二区| 一区二区在线观看视频| 精品3d动漫视频一区在线观看| 成人免费视频一区| 一区二区国产在线观看| 国产日韩精品一区二区三区在线| 久久一区二区精品综合| 99精品国产一区二区三区2021| 蜜桃AV抽搐高潮一区二区| 高清一区二区三区视频| 亚洲av无码一区二区三区不卡| 中文字幕乱码一区久久麻豆樱花| 国产日韩精品一区二区三区 | 亚洲av无码一区二区三区人妖| 精品日韩一区二区| 日本亚洲国产一区二区三区| 亚洲香蕉久久一区二区| 一级毛片完整版免费播放一区| 亚洲人成人一区二区三区| 国产精品一区二区久久精品涩爱| 一区二区三区免费视频网站 | 一区二区三区在线|欧| 日韩视频一区二区| 日韩精品一区二区三区中文| 国产一区二区精品在线观看| 国产成人精品无码一区二区| 国产激情一区二区三区在线观看 | 一区二区不卡久久精品| 色噜噜狠狠一区二区| 国模丽丽啪啪一区二区| 国产精品无码亚洲一区二区三区| 中文字幕精品亚洲无线码一区应用 | 中文字幕无码不卡一区二区三区| 超清无码一区二区三区| 免费看AV毛片一区二区三区| 日韩人妻不卡一区二区三区| 久久国产高清一区二区三区| 精品国产免费一区二区| 91秒拍国产福利一区| 精品人妻一区二区三区毛片| 亚洲性无码一区二区三区|