JSP隨機驗證圖片如何制作
更新時間:2015年10月02日 13:08:07 投稿:lijiao
這篇文章主要介紹了JSP隨機驗證圖片是如何制作的,感興趣的朋友可以參考一下
小編整理了一篇關于模仿騰訊隨機驗證圖片的文章。下面直接上代碼吧!一個Java 類和一個JSP 頁面。
Java類代碼:
以下是JSP模仿騰訊隨機驗證圖片引用片段:
package icewee.image; import java.awt.BasicStroke; import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import java.awt.RenderingHints; import java.awt.geom.Line2D; import java.awt.image.BufferedImage; import java.util.Random; public class TokenUtil { private static final String base = "23456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefhijklmnpqrstuvwxyz"; private static final int length = base.length(); public static BufferedImage createTokenImage(int width, int height, String randomCode) { BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics2D g = image.createGraphics(); Random random = new Random(); g.setColor(new Color(230, 230, 250)); // 設置背景色 g.fillRect(0, 0, width, height); // 填充背景 g.setColor(Color.BLACK); // 繪制邊緣 g.drawRect(-1, -1, width + 1, height + 1); g.setColor(Color.GRAY); // 設置字體,隨機選擇字體,暫設置8種字體 Font font = new Font((new String[] { "Arial", "Arial Black", "Arial Italic", "Courier New", "Courier New Bold Italic", "Courier New Italic", "Franklin Gothic Medium", "Franklin Gothic Medium Italic" })[random.nextInt(8)], Font.PLAIN, 30); // g.setStroke(new BasicStroke((float)(Math.random()), // BasicStroke.CAP_BUTT, BasicStroke.JOIN_BEVEL)); g.setFont(font); // 定義字體顏色范圍 int red = random.nextInt(160), green = random.nextInt(50), blue = random .nextInt(50); // 定義一個無干擾線區(qū)間和一個起始位置 int nor = random.nextInt(50), rsta = random.nextInt(131); // 繪制干擾正弦曲線 M:曲線平折度, D:Y軸常量 V:X軸焦距 int M = random.nextInt(15) + 5, D = random.nextInt(23) + 15, V = random .nextInt(5) + 1; double x = 0.0; double y = M * Math.sin(Math.toRadians(V * x)) + D; double px, py; for (int i = 0; i < 131; i++) { px = x + 1; py = M * Math.sin(Math.toRadians(V * px)) + D; if (rsta < i && i < (rsta + nor)) g.setColor(new Color(230, 230, 250)); else g.setColor(new Color(red, green, blue)); // 隨機設置像素點寬帶(線寬) g.setStroke(new BasicStroke((float) (Math.random() + 1.5f))); g.draw(new Line2D.Double(x, y, px, py)); x = px; y = py; } char[] codes = randomCode.toCharArray(); for (int i = 0; i < codes.length; i++) { // 旋轉(zhuǎn)圖形 int degree = (random.nextInt(20) - 10) % 360; double ang = degree * 0.0174532925; // 將角度轉(zhuǎn)為弧度 g.rotate(ang, width / 2, height / 2); g.setColor(new Color(red, green, blue)); g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON); int gr = random.nextInt(8); g.drawString(String.valueOf(codes[i]), 24 * i + 10 + gr, 38); } g.dispose(); return image; } public static String createRandomCode(int size, int width, int height) { StringBuffer randomCode = new StringBuffer(); for (int i = 0; i < size; i++) { Random random = new Random(); int start = random.nextInt(length); String strRand = base.substring(start, start + 1); randomCode.append(strRand); } return randomCode.toString(); } }
JSP頁面:
以下是JSP模仿騰訊隨機驗證圖片代碼引用片段:
<%@ page contentType="image/jpeg" pageEncoding="GBK"%> <%@ page import="java.awt.image.BufferedImage" %> <%@page import="javax.imageio.ImageIO" %> <%@ page import="com.icesoft.image.TokenUtil" %> <% //設置頁面不緩存 response.setHeader("Pragma", "No-cache"); response.setHeader("Cache-Control", "no-cache"); response.setDateHeader("Expires", 0); int width = 120, height = 50; String randomCode = TokenUtil.createRandomCode(4, width, height); System.out.println("生成的隨機碼:" + randomCode); BufferedImage image = TokenUtil.createTokenImage(width, height, randomCode); ImageIO.write(image, "JPEG", response.getOutputStream()); response.flushBuffer(); out.clear(); out = pageContext.pushBody(); %>
以上就是JSP 模仿騰訊隨機驗證圖片全部代碼,希望對大家的學習有所幫助。
您可能感興趣的文章:
- 基于JavaScript代碼實現(xiàn)隨機漂浮圖片廣告
- javascript隨機顯示背景圖片的方法
- JavaScript實現(xiàn)隨機替換圖片的方法
- js鼠標點擊圖片實現(xiàn)隨機變換圖片的方法
- js實現(xiàn)網(wǎng)頁隨機切換背景圖片的方法
- javascript隨機將第一個dom中的圖片添加到第二個div中示例
- js 圖片隨機不定向浮動的實現(xiàn)代碼
- JavaScript 創(chuàng)建隨機數(shù)和隨機圖片
- javascript 隨機廣告代碼(圖片廣告)
- JS實現(xiàn)鼠標移動到縮略圖顯示大圖的圖片放大效果
- 圖片上傳即時顯示縮略圖的js代碼
- JS實現(xiàn)頁面載入時隨機顯示圖片效果
相關文章
JSP技術實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方法
實現(xiàn)動態(tài)頁面到靜態(tài)頁面以減小數(shù)據(jù)庫與服務器的壓力和負擔,這是很多實際開發(fā)應用工作當中的一個理想的解決辦法,那么本文就向你講解如何實現(xiàn)實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方案。2016-10-10JSP中操作數(shù)據(jù)庫的常用SQL標簽用法總結
這篇文章主要介紹了JSP中操作數(shù)據(jù)庫的常用SQL標簽用法總結,SQL標簽封裝了數(shù)據(jù)庫訪問的通用邏輯,可以簡化數(shù)據(jù)庫操作,需要的朋友可以參考下2016-04-04Spring 自動代理創(chuàng)建器詳細介紹及簡單實例
這篇文章主要介紹了Spring 自動代理創(chuàng)建器詳細介紹及簡單實例的相關資料,需要的朋友可以參考下2017-02-02