JSP隨機驗證圖片如何制作
更新時間:2015年10月02日 13:08:07 投稿:lijiao
這篇文章主要介紹了JSP隨機驗證圖片是如何制作的,感興趣的朋友可以參考一下
小編整理了一篇關(guān)于模仿騰訊隨機驗證圖片的文章。下面直接上代碼吧!一個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)); // 設(shè)置背景色
g.fillRect(0, 0, width, height); // 填充背景
g.setColor(Color.BLACK);
// 繪制邊緣
g.drawRect(-1, -1, width + 1, height + 1);
g.setColor(Color.GRAY);
// 設(shè)置字體,隨機選擇字體,暫設(shè)置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));
// 隨機設(shè)置像素點寬帶(線寬)
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" %>
<%
//設(shè)置頁面不緩存
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 模仿騰訊隨機驗證圖片全部代碼,希望對大家的學(xué)習(xí)有所幫助。
您可能感興趣的文章:
- 基于JavaScript代碼實現(xiàn)隨機漂浮圖片廣告
- javascript隨機顯示背景圖片的方法
- JavaScript實現(xiàn)隨機替換圖片的方法
- js鼠標(biāo)點擊圖片實現(xiàn)隨機變換圖片的方法
- js實現(xiàn)網(wǎng)頁隨機切換背景圖片的方法
- javascript隨機將第一個dom中的圖片添加到第二個div中示例
- js 圖片隨機不定向浮動的實現(xiàn)代碼
- JavaScript 創(chuàng)建隨機數(shù)和隨機圖片
- javascript 隨機廣告代碼(圖片廣告)
- JS實現(xiàn)鼠標(biāo)移動到縮略圖顯示大圖的圖片放大效果
- 圖片上傳即時顯示縮略圖的js代碼
- JS實現(xiàn)頁面載入時隨機顯示圖片效果
相關(guān)文章
JSP技術(shù)實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方法
實現(xiàn)動態(tài)頁面到靜態(tài)頁面以減小數(shù)據(jù)庫與服務(wù)器的壓力和負擔(dān),這是很多實際開發(fā)應(yīng)用工作當(dāng)中的一個理想的解決辦法,那么本文就向你講解如何實現(xiàn)實現(xiàn)動態(tài)頁面到靜態(tài)頁面的方案。2016-10-10
JSP中操作數(shù)據(jù)庫的常用SQL標(biāo)簽用法總結(jié)
這篇文章主要介紹了JSP中操作數(shù)據(jù)庫的常用SQL標(biāo)簽用法總結(jié),SQL標(biāo)簽封裝了數(shù)據(jù)庫訪問的通用邏輯,可以簡化數(shù)據(jù)庫操作,需要的朋友可以參考下2016-04-04
jsp傳值本地?zé)o亂碼測試機出現(xiàn)亂碼問題解決
在本地使用jsp傳值時,一切正常無亂碼,當(dāng)放到測試機上是發(fā)現(xiàn)有亂碼現(xiàn)象,針對此問題本文給出詳細的解決方案,感興趣的朋友可以參考下哈2013-04-04
Spring 自動代理創(chuàng)建器詳細介紹及簡單實例
這篇文章主要介紹了Spring 自動代理創(chuàng)建器詳細介紹及簡單實例的相關(guān)資料,需要的朋友可以參考下2017-02-02

