Java 生成隨機(jī)驗(yàn)證碼圖片的示例
1.情景展示
登錄時(shí),生成隨機(jī)驗(yàn)證碼圖片,如何實(shí)現(xiàn)?
2.原因分析
后臺(tái)生成驗(yàn)證碼并生成圖片返回至前臺(tái)
3.解決方案
導(dǎo)包
import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.image.BufferedImage;import java.util.Random;import javax.imageio.ImageIO;import javax.servlet.ServletOutputStream;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServletResponse;import org.apache.commons.lang.RandomStringUtils;import base.web.tools.WebUtils;
獲取驗(yàn)證碼請(qǐng)求處理
/** * 獲取驗(yàn)證碼 * @explain * @return 隨機(jī)數(shù)圖片 */public String getImage() { try {int width = 55;int height = 25;// 取得一個(gè)4位隨機(jī)數(shù)字字符串String s = RandomStringUtils.randomNumeric(4);HttpServletResponse response = WebUtils.getResponse();// 存入cookie,用于與用戶的輸入進(jìn)行比較Cookie cookie = new Cookie('validateCode', s);response.addCookie(cookie);response.setContentType('images/jpeg');response.setHeader('Cache-Control', 'no-cache'); ServletOutputStream out = response.getOutputStream();BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);Graphics g = image.getGraphics();// 設(shè)定背景色g.setColor(getRandColor(200, 250));g.fillRect(0, 0, width, height); // 設(shè)置字體Font mFont = new Font('宋體', Font.BOLD, 18);g.setFont(mFont); // 畫邊框// g.setColor(Color.BLACK);// g.drawRect(0, 0, width - 1, height - 1); // 生成隨機(jī)類Random random = new Random();// 將認(rèn)證碼顯示到圖象中g(shù).setColor(new Color(20 + random.nextInt(110), 20 + random.nextInt(110), 20 + random.nextInt(110)));// 將驗(yàn)證碼畫進(jìn)圖片g.drawString(s, 5, 20);// 圖象生效g.dispose();// 輸出圖象到頁面ImageIO.write((BufferedImage) image, 'JPEG', out);out.flush();out.close(); } catch (Exception e) {e.printStackTrace(); } return null;} /** * 給定范圍獲得隨機(jī)顏色 * @explain * @param fc * @param bc * @return */private Color getRandColor(int fc, int bc) { Random random = new Random(); fc = (fc > 255) ? 255 : fc; bc = (bc > 255) ? 255 : bc; // 獲取3次 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);}
html片段
<img src='http://www.cgvv.com.cn/bcjs/<c:url value='/getImage.do'/>' onclick=’sjs()’ />
js片段
function sjs () { // 獲取圖片請(qǐng)求后面加一個(gè)隨機(jī)參數(shù),是為了避免同一個(gè)請(qǐng)求瀏覽器拒絕向服務(wù)器發(fā)送請(qǐng)求的問題(緩存) $('#randomImage')[0].src = baseUrl + '/getImage.do?s=' + Math.random();};
寫在最后
哪位大佬如若發(fā)現(xiàn)文章存在紕漏之處或需要補(bǔ)充更多內(nèi)容,歡迎留言?。。?/p>
本文作者:Marydon
原文鏈接:https://www.cnblogs.com/Marydon20170307/p/12807842.html
以上就是Java 生成隨機(jī)驗(yàn)證碼圖片的示例的詳細(xì)內(nèi)容,更多關(guān)于Java 生成驗(yàn)證碼的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. python中scrapy處理項(xiàng)目數(shù)據(jù)的實(shí)例分析2. Python中讀取文件名中的數(shù)字的實(shí)例詳解3. 在idea中為注釋標(biāo)記作者日期操作4. 通過Ajax方式綁定select選項(xiàng)數(shù)據(jù)的實(shí)例5. JSP頁面的靜態(tài)包含和動(dòng)態(tài)包含使用方法6. ASP.Net Core對(duì)USB攝像頭進(jìn)行截圖7. ASP.NET MVC使用Boostrap實(shí)現(xiàn)產(chǎn)品展示、查詢、排序、分頁8. .net如何優(yōu)雅的使用EFCore實(shí)例詳解9. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟10. ajax動(dòng)態(tài)加載json數(shù)據(jù)并詳細(xì)解析
