欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

J2EE驗證碼圖片如何生成和點擊刷新驗證碼

 更新時間:2016年04月29日 12:02:01   作者:justPassBy  
這篇文章主要介紹了J2EE如何生成驗證碼圖片如何生成,如何點擊刷新驗證碼的相關方法,感興趣的小伙伴們可以參考一下

驗證碼圖片生成步驟

創(chuàng)建BufferedImage對象。
獲取BufferedImage的畫筆,即調用getGraphics()方法獲取Graphics對象。
調用Graphics對象的setColor()方法和fillRect()方法設置圖片背景顏色。
調用Graphics對象的setColor()方法和drawLine()方法設置圖片干擾線。
調用BufferedImaged對象的setRGB()方法設置圖片的噪點。
調用Graphics對象的setColor()方法、setFont()方法和drawString()方法設置圖片驗證碼。

因為驗證碼的圖片的寬度和高度要根據(jù)網(wǎng)站的風格來確定的,所以字體的大小需要根據(jù)圖片的寬度和高度來確定,用到了小小的技巧。

package util;

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Random;

import javax.imageio.ImageIO;

public class Verification {
  private static final String ALPHABET = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890";
  
  /**
   * 生成一個寬為width, 高為height, 驗證碼為code的圖片
   * @param width 圖片的寬
   * @param height 圖片的高
   * @param code 驗證碼字符串
   * @return 返回圖片驗證碼
   */
  public static BufferedImage getImage(int width, int height, String code){
    return getImage(width, height, code, 20);
  }
  /**
   * 生成一個寬為width, 高為height, 驗證碼為code的圖片,圖片中干擾線的條數(shù)為lineCnt
   * @param width 圖片的寬
   * @param height 圖片的高
   * @param code 驗證碼字符串
   * @param lineCnt 干擾線的條數(shù),建議為10條左右,可根據(jù)結果適當調整
   * @return 返回圖片驗證碼
   */
  public static BufferedImage getImage(int width, int height, String code, int lineCnt){
    return createImage(width, height, code, lineCnt, 0.01);
  }
  /**
   * 生成一個寬為width, 高為height, 驗證碼為code的圖片,圖片中干擾線的條數(shù)為lineCnt
   * 噪聲比為noiseRate,即圖片中噪音像素點的百分比
   * @param width 圖片的寬
   * @param height 圖片的高
   * @param code 驗證碼字符串
   * @param lineCnt 干擾線的條數(shù),建議為10條左右,可根據(jù)結果適當調整
   * @param noiseRate 圖片中噪音像素點占總像素的百分比
   * @return 返回圖片驗證碼
   */
  public static BufferedImage getImage(int width, int height, String code, int lineCnt, double noiseRate){
    return createImage(width, height, code, lineCnt, noiseRate);
  }
  
  /**
   * 
   * 生成一個寬為width, 高為height, 驗證碼為code的圖片,圖片中干擾線的條數(shù)為lineCnt
   * 噪聲比為noiseRate,即圖片中噪音像素點的百分比
   * @param width 圖片的寬
   * @param height 圖片的高
   * @param code 驗證碼字符串
   * @param lineCnt 干擾線的條數(shù),建議為10條左右,可根據(jù)結果適當調整
   * @param noiseRate 圖片中噪音像素點占總像素的百分比
   * @return 返回圖片驗證碼
   */
  private static BufferedImage createImage(int width, int height, String code, int lineCnt, double noiseRate){
    int fontWidth = ((int)(width * 0.8)) / code.length();
    int fontHeight = (int)(height * 0.7);
    //為了在任意的width和height下都能生成良好的驗證碼,
    //字體的大小為fontWdith何fontHeight中的小者,
    int fontSize = Math.min(fontWidth, fontHeight);
    //drawString時要用到
    int paddingX = (int) (width * 0.1);
    int paddingY = height - (height - fontSize) / 2;
    
    //創(chuàng)建圖像
    BufferedImage buffimg = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
    //獲得畫筆
    Graphics g = buffimg.getGraphics();
    //設置畫筆的顏色
    g.setColor(getRandColor(200, 255));
    //然后填充一個矩形,即設置背景色
    g.fillRect(0, 0, width, height);
    
    // 設置干擾線
    for (int i = 0; i < lineCnt; i++) {
        //隨機獲取干擾線的起點和終點
      int xs = (int)(Math.random() * width);
      int ys = (int)(Math.random() * height);
      int xe = (int)(Math.random() * width);
      int ye = (int)(Math.random() * height);
      g.setColor(getRandColor(1, 255));
      g.drawLine(xs, ys, xe, ye);
    }
    // 添加噪點
    int area = (int) (noiseRate * width * height);
    for(int i=0; i<area; ++i){
        int x = (int)(Math.random() * width);
        int y = (int)(Math.random() * height);
        buffimg.setRGB(x, y, (int)(Math.random() * 255));
    }
    //設置字體
    Font font = new Font("Ravie", Font.PLAIN, fontSize);
    g.setFont(font);
    
    for(int i=0; i<code.length(); ++i){
        String ch = code.substring(i, i+1);
        g.setColor(getRandColor(1, 199));
        g.drawString(ch, paddingX + fontWidth * i, paddingY);
    }
    return buffimg;
    
  }
  /**
   * 獲取隨機的顏色,r,g,b的取值在L到R之間
   * @param L 左區(qū)間
   * @param R 右區(qū)間
   * @return 返回隨機顏色值
   */
  private static Color getRandColor(int L, int R){
    if(L > 255)
      L = 255;
    if(R > 255)
      R = 255;
    if(L < 0)
      L = 0;
    if(R < 0)
      R = 0;
    int interval = R - L; 
    int r = L + (int)(Math.random() * interval);
    int g = L + (int)(Math.random() * interval);
    int b = L + (int)(Math.random() * interval);
    return new Color(r, g, b);
  }

  /**
   * 隨機生成若干個由大小寫字母和數(shù)字組成的字符串
   * @param len 隨機生成len個字符
   * @return 返回隨機生成的若干個由大小寫字母和數(shù)字組成的字符串
   */
  public static String getRandCode(int len){
    String code = "";
    for(int i=0; i<len; ++i){
      int index = (int)(Math.random() * ALPHABET.length());
      code = code + ALPHABET.charAt(index);
    }
    return code;
  }
  /**
   * 將圖片轉為byte數(shù)組
   * @param image 圖片
   * @return 返回byte數(shù)組
   * @throws IOException
   */
  public static byte[] getByteArray(BufferedImage image) throws IOException{
    ByteArrayOutputStream baos = new ByteArrayOutputStream();
    ImageIO.write(image, "png", baos);
    return baos.toByteArray();
    //ByteArrayOutputStream 不需要close
    
  }
}

使用驗證碼圖片

在verificationCode.java這個servlet中調用上面的類生成驗證碼圖片,然后將圖片返回給客戶端。

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    HttpSession session = request.getSession();
    //隨機生成字符串,并寫入session
    String code = Verification.getRandCode(4);
    session.setAttribute("verification", code);
    BufferedImage image = util.Verification.getImage(100,30, code, 5);
    response.setContentType("image/png");
    
    OutputStream out = response.getOutputStream();
    out.write(util.Verification.getByteArray(image));
    out.flush();
    out.close();
    
  }
 

在index.jsp中設置驗證碼,用戶點擊驗證碼時,調用js代碼請求服務器得到新的驗證碼。因為上面的那個生成驗證碼的servlet會被瀏覽器緩存,所以js代碼中需要給該servlet一個隨機的參數(shù),這樣瀏覽器就會向服務器發(fā)請求得到新的驗證碼,而不是去緩存中讀取。

<%@page import="util.Verification"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>Insert title here</title>

<script type="text/javascript">
    function refreshcode(){
      document.getElementById("verification").src= "/verificationCode/verificationCode?hehe="+Math.random();
    }
  </script>
</head>
<body>
  
  <form action="<%=request.getContextPath()+"/checkVerification" %>" method="post">
    驗證碼:<input type="text" name="submitVerification">
    <img id="verification" alt="" title="看不清點擊刷新驗證碼" src="<%=request.getContextPath()+"/verificationCode" %>"
    onclick="refreshcode()"><br>
    <input type="submit" name="submit" value="提交">
  </form>
  
</body>
</html>

最后是在checkVerification.java這個servlet中判斷用戶輸入的驗證碼是否正確,為了方便用戶,驗證碼一般都設置成大小寫不敏感,所以要先轉化為小寫字母再比對。

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  HttpSession session = request.getSession();
  String verification = (String)session.getAttribute("verification");
  String submitVerification = request.getParameter("submitVerification");
  PrintWriter out = response.getWriter();
  if(verification!=null && submitVerification!=null){
   if(verification.toLowerCase().equals(submitVerification.toLowerCase())){
    out.println("yes!!!");
   }
   else{
    out.println("no!!!");
   }
   
  }
  else{
   out.println("no!!!");
  }
  session.removeAttribute("verification");//防止用戶重復提交表單

 }

 /**
  * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
  */
 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  // TODO Auto-generated method stub
  doGet(request, response);
 }

最后運行的效果圖如下

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。

相關文章

  • java?System類和Arrays類詳解

    java?System類和Arrays類詳解

    這篇文章主要介紹了java?System類和Arrays類詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • MyBatis使用<foreach>標簽報錯問題及解決

    MyBatis使用<foreach>標簽報錯問題及解決

    這篇文章主要介紹了MyBatis使用<foreach>標簽報錯問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 基于SpringBoot+vue實現(xiàn)前后端數(shù)據(jù)加解密

    基于SpringBoot+vue實現(xiàn)前后端數(shù)據(jù)加解密

    這篇文章主要給大家介紹了基于SpringBoot+vue實現(xiàn)前后端數(shù)據(jù)加解密,文中有詳細的示例代碼,具有一定的參考價值,感興趣的小伙伴可以自己動手試一試
    2023-08-08
  • Java實現(xiàn)的文件上傳下載工具類完整實例【上傳文件自動命名】

    Java實現(xiàn)的文件上傳下載工具類完整實例【上傳文件自動命名】

    這篇文章主要介紹了Java實現(xiàn)的文件上傳下載工具類,結合完整實例形式分析了java針對文件上傳下載操作的相關實現(xiàn)技巧,并且針對上傳文件提供了自動命名功能以避免文件命名重復,需要的朋友可以參考下
    2017-11-11
  • java使用Filter實現(xiàn)自動登錄的方法

    java使用Filter實現(xiàn)自動登錄的方法

    這篇文章主要為大家詳細介紹了java使用Filter實現(xiàn)自動登錄的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • mybatis-puls中的resultMap數(shù)據(jù)映射

    mybatis-puls中的resultMap數(shù)據(jù)映射

    這篇文章主要介紹了mybatis-puls中的resultMap數(shù)據(jù)映射,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • 利用spring-data-redis實現(xiàn)incr自增的操作

    利用spring-data-redis實現(xiàn)incr自增的操作

    這篇文章主要介紹了利用spring-data-redis實現(xiàn)incr自增的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Java多線程中Callable和Future的解讀

    Java多線程中Callable和Future的解讀

    這篇文章主要介紹了Java多線程中Callable和Future的解讀,Callable接口類似于Runnable,從名字就可以看出來了,但是Runnable不會返回結果,并且無法拋出返回結果的異常,而Callable功能更強大一些,被線程執(zhí)行后,可以返回值,這個返回值可以被Future拿到,需要的朋友可以參考下
    2023-09-09
  • Java多線程編程詳細解釋

    Java多線程編程詳細解釋

    這篇文章主要介紹了java多線程編程實例,分享了幾則多線程的實例代碼,具有一定參考價值,加深多線程編程的理解還是很有幫助的,需要的朋友可以參考下。
    2021-11-11
  • Java pdf和jpg互轉案例

    Java pdf和jpg互轉案例

    這篇文章主要介紹了Java pdf和jpg互轉案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09

最新評論