java原生動態生成驗證碼
阿新 • • 發佈:2020-10-12
本文例項為大家分享了java原生動態生成驗證碼的具體程式碼,供大家參考,具體內容如下
需求描述: 為了防止指令碼多次請求,很多時候在註冊會用到驗證碼,我們用java實現 一個圖片驗證的二維碼。
專案結構
只有 標記的這三個檔案是用到的
CheckServlet核心程式碼
package lhw.wanlin.checkimg; import javax.imageio.ImageIO; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.awt.*; import java.awt.image.BufferedImage; import java.io.BufferedReader; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.IOException; import java.util.ArrayList; import java.util.List; import java.util.Random; @WebServlet(name = "CheckServlet") public class CheckServlet extends HttpServlet { //集中儲存所有成語 private List<String> words = new ArrayList<>(); @Override public void init() throws ServletException { // 初始化階段,讀取new_words.txt // web工程中讀取 檔案,必須使用絕對磁碟路徑 String path = getServletContext().getRealPath("/WEB-INF/new_words.txt"); try { BufferedReader br = new BufferedReader(new FileReader(path)); String line; while ((line = br.readLine()) != null){ words.add(line); } br.close(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } protected void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException { this.doGet(request,response); } protected void doGet(HttpServletRequest request,IOException { // 禁止快取 // response.setHeader("Cache-Control","no-cache"); // response.setHeader("Pragma","no-cache"); // response.setDateHeader("Expires",-1); System.out.println(words); int width = 120; int height = 30; // 步驟一 繪製一張記憶體中圖片 BufferedImage bufferedImage = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB); // 步驟二 圖片繪製背景顏色 ---通過繪圖物件 Graphics graphics = bufferedImage.getGraphics();// 得到畫圖物件 --- 畫筆 // 繪製任何圖形之前 都必須指定一個顏色 graphics.setColor(getRandColor(200,250)); graphics.fillRect(0,width,height); // 步驟三 繪製邊框 graphics.setColor(Color.WHITE); graphics.drawRect(0,width - 1,height - 1); // 步驟四 四個隨機數字 Graphics2D graphics2d = (Graphics2D) graphics; // 設定輸出字型 graphics2d.setFont(new Font("宋體",Font.BOLD,18)); Random random = new Random();// 生成隨機數 int index = random.nextInt(words.size()); String word = words.get(index);// 獲得成語 // 定義x座標 int x = 10; for (int i = 0; i < word.length(); i++) { // 隨機顏色 graphics2d.setColor(new Color(20 + random.nextInt(110),20 + random .nextInt(110),20 + random.nextInt(110))); // 旋轉 -30 --- 30度 int jiaodu = random.nextInt(60) - 30; // 換算弧度 double theta = jiaodu * Math.PI / 180; // 獲得字母數字 char c = word.charAt(i); // 將c 輸出到圖片 graphics2d.rotate(theta,x,20); graphics2d.drawString(String.valueOf(c),20); graphics2d.rotate(-theta,20); x += 30; } // 將驗證碼內容儲存session request.getSession().setAttribute("checkcode_session",word); // 步驟五 繪製干擾線 graphics.setColor(getRandColor(160,200)); int x1; int x2; int y1; int y2; for (int i = 0; i < 30; i++) { x1 = random.nextInt(width); x2 = random.nextInt(12); y1 = random.nextInt(height); y2 = random.nextInt(12); graphics.drawLine(x1,y1,x1 + x2,x2 + y2); } // 將上面圖片輸出到瀏覽器 ImageIO graphics.dispose();// 釋放資源 //將圖片寫到response.getOutputStream()中 ImageIO.write(bufferedImage,"jpg",response.getOutputStream()); } /** * 取其某一範圍的color * * @param fc * int 範圍引數1 * @param bc * int 範圍引數2 * @return Color */ private Color getRandColor(int fc,int bc) { // 取其隨機顏色 Random random = new Random(); if (fc > 255) { fc = 255; } if (bc > 255) { bc = 255; } int r = fc + random.nextInt(bc - fc); int g = fc + random.nextInt(bc - fc); int b = fc + random.nextInt(bc - fc); return new Color(r,g,b); } }
web.xml配置檔案
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <servlet> <servlet-name>CheckServlet</servlet-name> <servlet-class>lhw.wanlin.checkimg.CheckServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>CheckServlet</servlet-name> <url-pattern>/checkServlet</url-pattern> </servlet-mapping> </web-app>
new_words.txt文字檔案
一唱一和
一呼百應
一乾二淨
一舉兩得
一落千丈
執行效果
這樣就動態生成了 圖片二維碼
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。