一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java 制作驗證碼并進行驗證實例詳解

java 制作驗證碼并進行驗證實例詳解

2020-09-17 15:02shuaicihai Java教程

這篇文章主要介紹了java 制作驗證碼并進行驗證實例詳解的相關資料,需要的朋友可以參考下

java 制作驗證碼并進行驗證實例詳解

在注冊、登錄的頁面上經常會出現驗證碼,為了防止頻繁的注冊或登錄行為。下面是我用java制作的一個驗證碼,供初學者參考,做完驗證碼之后,我們可以用ajax進行驗證碼驗證。

功能一:驗證碼制作的代碼,點擊圖片,驗證碼進行更換

?
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
/**
 * 顯示驗證碼圖片
 */
public void showCheckCode(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
  // 調用業務邏輯
  String checkCode = getCheckCode();
  //將驗證碼字符放入session域對象中
  req.getSession().setAttribute("checkCode", checkCode);
 
  //圖片寬
  int width = 80;
  //圖片高
  int height = 30;
  //在內存中創建一個圖片
  BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
  //獲取一個畫筆
  Graphics g = image.getGraphics();
  //設置畫筆顏色,用灰色做背景
  g.setColor(Color.GRAY);
  //向Image中填充灰色
  g.fillRect(0,0,width,height);
 
  Random r = new Random();
 
  //設置3條干擾線
  for (int i = 0; i < 3; i++) {
    g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
    g.drawLine(r.nextInt(80), r.nextInt(30), r.nextInt(80), r.nextInt(80));
  }
 
  //設置驗證碼字符串的顏色
  g.setColor(new Color(r.nextInt(255),r.nextInt(255),r.nextInt(255)));
  //設置字符的大小
  g.setFont(new Font("黑體",Font.BOLD,24));
  //在圖片中寫入驗證碼字符串
  g.drawString(checkCode,15,20);
  //將Image對象以PNG格式輸出給所有的客戶端
  ImageIO.write(image,"PNG",resp.getOutputStream());
}
 
/**
 * 獲取4位驗證碼中的4位隨機字符串
 */
public static String getCheckCode(){
  //驗證碼中的字符由數字和大小寫字母組成
  String code = "0123456789qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM";
  Random r = new Random();
  StringBuffer sb = new StringBuffer();
  for (int i = 0; i < 4; i++) {
    sb.append(code.charAt(r.nextInt(code.length())));
  }
 
  return sb.toString();
}

jsp頁面

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<script type="text/javascript">
  function changeCodeImage(img){
    img.src = "${pageContext.request.contextPath}/UserServlet?method=showCheckCode&time="+new Date().getTime();
  }
 
</script>
 
 <div class="form-group">
  <label for="date" class="col-sm-2 control-label">驗證碼</label>
  <div class="col-sm-3">
   <input type="text" class="form-control" id="writeCode" onkeyup="checkCodeMethod(this.value)" >
 
  </div>
  <div class="col-sm-2">
  <img src="${pageContext.request.contextPath}/UserServlet?method=showCheckCode" id="checkCodeImage" title="點擊換一張" onclick="changeCodeImage(this)" />
  </div>
  <span id="checkCodeSpan"></span>
 </div>

功能二:ajax動態驗證驗證碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/**
 * 驗證驗證碼
 */
public void checkCode(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
 
  //獲取從頁面中接收到的驗證碼參數
  String checkCode = req.getParameter("checkCode");
  //從session域對象中獲取驗證碼
  String sessionCode = (String) req.getSession().getAttribute("checkCode");
  //判斷驗證碼是否相同
  if (checkCode.equalsIgnoreCase(sessionCode)) {
    resp.getWriter().print(true);
  }else {
    resp.getWriter().print(false);
  }

jsp頁面

?
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
<script type="text/javascript">
  function changeCodeImage(img){
    img.src = "${pageContext.request.contextPath}/UserServlet?method=showCheckCode&time="+new Date().getTime();
  }
 
  function checkCodeMethod(code){
    $.get("${pageContext.request.contextPath}/UserServlet?method=checkCode",
        { checkCode: code},
        function(data){
          if (data == 'true') {
            document.getElementById("checkCodeSpan").innerHTML = "<font>驗證碼正確!</font>";
          }else {
            document.getElementById("checkCodeSpan").innerHTML = "<font>驗證碼錯誤!</font>";
          }
        }
      );
  }
 
</script>
 
 <div class="form-group">
  <label for="date" class="col-sm-2 control-label">驗證碼</label>
  <div class="col-sm-3">
   <input type="text" class="form-control" id="writeCode" onkeyup="checkCodeMethod(this.value)" >
 
  </div>
  <div class="col-sm-2">
  <img src="${pageContext.request.contextPath}/UserServlet?method=showCheckCode" id="checkCodeImage" title="點擊換一張" onclick="changeCodeImage(this)" />
  </div>
  <span id="checkCodeSpan"></span>
 </div>

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

原文鏈接:http://blog.csdn.net/shuaicihai/article/details/54730590

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲日本中文字幕在线2022 | 99久热只有精品视频免费看 | 扒开黑女人p大荫蒂老女人 扒开大腿狠狠挺进视频 | 免费人成在线观看69式小视频 | 青青热久免费精品视频网站 | 办公室大战秘书呻吟 | 欧美人伦禁忌.5 | 欧美精品色精品一区二区三区 | 无码人妻精品一区二区蜜桃在线看 | 99热久久这里只有精品6国产网 | 8x8x华人免费| 暖暖视频免费观看视频中国.韩剧 | 岛国最新资源网站 | 亚洲视频高清 | 北海市副市长黄江老公 | 天天性综合 | 我的绝色岳每雯雯 | 99年水嫩漂亮粉嫩在线播放 | 午夜想想爱| 99精品视频只99有精品 | 国产成人精品本亚洲 | 99热国产在线 | 亚洲福利一区 | 任我行视频在线观看国语 | 国产综合亚洲欧美日韩一区二区 | 日韩在线中文字幕 | 成人一区二区丝袜美腿 | 啪啪导航 | 久久精品一区二区三区资源网 | 丝瓜视频黄色在线观看 | 精品无码国产AV一区二区三区 | 精品一二三区久久AAA片 | dasd817黑人在线播放 | 国产免费成人在线视频 | 拔插拔插8x8x海外华人免费视频 | 91精品国产99久久 | 男人免费视频 | 日本无遮挡亲吻膜下面免费 | 免费视频片在线观看大片 | 娜娜啪| 亚洲黄色图 |